解题思路:解本题时,基本思路是,先求阶乘,再求阶乘的和。  自定义函数求阶乘。循环作和。

注意事项:1.采取自定函数求阶乘。用递归法。需注意递归法的尽头。(在本题中,fac函数的if语句作递归法的尽头,不可省略。)

              2.要注意最后结果的数值范围,避免溢出发生错误。

参考代码

#include<stdio.h>
long int fac(unsigned int n)  //定义为long int 型,避免溢出
{
    long int f;
    if(n==0) return 1;        //当n=0是,递归法到尽头,依次返回函数值。
    f=fac(n-1)*n;
    return (f);               //返回最后一次函数值,即单次阶乘的最后结果
}

int main()
{
    unsigned int n;
    long int s=0;
    int i;
    scanf("%d",&n);
    for(i=1;i<=n;i++)  s+=fac(i);    //以循环控制阶乘的和。fac函数每一次的返回值作为s的自加值
    printf("%ld",s);
    return 0;
}


点赞(16)
 

0.0分

45 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 137 条评论

风清扬 5年前 回复TA
@小白到大神 用long sum。 long int 不行
你敲代码像CXK 5年前 回复TA
@小白到大神 #include <stdio.h>  long int factorial(int i){     long int sum=1;     if(i==0){         sum=1;     }     else{         for(int k=1;k<=i;k++){             sum*=k;         }     }     return sum; }  int main(){     int n=0,i=1;     long int sum=0;     scanf("%d",&n);     while(i<=n){         sum+=factorial(i);         i++;     }     printf("%ld",sum);     return 0; }请问哪里错了?一直说答案错误50%
小白到大神 5年前 回复TA
这道题答案错误50%的小可爱们注意精度,用long int型
飞羽 5年前 回复TA
@非于 main()写成void main()
飞羽 5年前 回复TA
main()写成void main()
Realline 5年前 回复TA
@非于 可能是因为阶乘是整数,你用的double型
非于 6年前 回复TA
#include<stdio.h>

main()
{
	int n;
	int i;
	double a;
    double sum;
	scanf("%d",&n); 
	for(i=1,a=1,sum=0;i<=n;i++)
	{
    a=a*i;
    sum+=a;
	}
	printf("%.0lf",sum);
}为啥通过不了