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

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

q671383789 4年前 回复TA
long int当n过大的时候还是会溢出啊哥哥
许某 4年前 回复TA
@鱼儿。 溢出了,装不了那么大的数
鱼儿。 4年前 回复TA
#include<stdio.h>
int fun(int n)
{
    if(n==1)
        return 1;
    return (n*fun(n-1));
}
int main() 
{
    int a,n,t,sum=0;
    scanf("%d",&n);
    for(a=1;a<=n;a++)
    sum+=fun(a);
    printf("%d",sum);
    return 0;
}

为什么显示错误50%,大神求解
Garbage. 4年前 回复TA
@小太阳 应该是long int s=1,你试试
薇薇 4年前 回复TA
@114514 @sjdjcjak 问题解决了么,如果没有,除了把int 改成 long int,输出也要改("%ld,sum")
114514 4年前 回复TA
@114514 @qq736372071 还是答案错误50%。。。。。我是哪个步骤出错了吗
114514 4年前 回复TA
@114514 还是答案错误50%。。。。。我是哪个步骤出错了吗
心如薄荷天然凉 4年前 回复TA
@cjlu123 n大概大于10的时候会溢出,把int 改成 long int就可以了
心如薄荷天然凉 4年前 回复TA
@114514 n大概大于10的时候会溢出,把int 改成 long int就可以了
心如薄荷天然凉 4年前 回复TA
@god n大概大于10的时候会溢出,把int 改成 long int就可以了