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

注意事项: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 条评论

luckyboy 4年前 回复TA
@金洛 其实可以更简单
^0^快乐 4年前 回复TA
@思无邪 int类型最大是2147483647,double类型可以输出20的阶乘
^0^快乐 4年前 回复TA
为什么错误50%
#include<stdio.h>
int main(void)
{
	double s=0,a=1.0;
	int i,n;
	scanf("%d",&n);
	if(n==0)
	{
		printf("1");	
	}
	else
	{
		for(i=1;i<=n;i++)
	{
		a=a*i;
		s+=a;
	}
	printf("%.0lf",s);
	}
	
	return 0;
}
狗头带崽 4年前 回复TA
@思无邪 输出结果为负数即为超出设定数据类型的取值范围
小娃安 4年前 回复TA
@你是年少的欢喜 0的阶乘是1
思无邪 4年前 回复TA
#include <stdio.h>
int main()
{
	int Sn=0,i=0,j=0,n=0,m=1;
	scanf("%d",&n);
	for(j=n;j>0;j--)
	{
		m=1;
		for(i=j;i>0;i--)
		{
			m=m*i;
		}
		Sn=Sn+m;
	}
	printf("%d",Sn);
	return 0;
}
这个代码为什么不行?在VC上运行是对的,这个题目的内存限定怎么看有没有超出?
Byrony 4年前 回复TA
@小太阳 数据太大溢出了,把int 改成long int 就可以了
小太阳 4年前 回复TA
#include<stdio.h>
int main()
{
	int n,i,sum=0,j,s;
	scanf("%d",&n);
	if(n==0||n==1)
	{
		sum=1;
	}
	else
	for(i=1;i<=n;i++)
	{
		s=1;
		for(j=1;j<=i;j++)
		{
		s=s*j;
		}
		sum=sum+s;
	}
	printf("%d",sum);
	return 0;
 } 
为啥错误%50
大王叫我来巡山 4年前 回复TA
@Singer 你试着不要在for里面定义i 放在for外面定义  int i
李哟哟 5年前 回复TA
@你是年少的欢喜 s1和Sn 那个改成long int 就行了  刚才试了一下