解题思路:

    先逐个进行求阶乘再进行累加

    思路确实简单,不过,阶乘很容出现数值溢出的问题,所以我们要扩大数值的存储范围


类型名称            字节数    取值范围
signed char           1        -128~+127
short int             2        -32768~+32767
int                   4        -2147483648~+2147483647
long int              4        -2147483648~+2141483647
long long int         8        -9223372036854775808~+9223372036854775807


//long int     的简写是     long          占位符是:%ld      
//long long int的简写是     long long     占位符是:%lld


    这些基础知识后我们就可以解题了


    为了减少程序的计算次数,我们可以看代码的第九行

    这里的t代表的是每一个循环的阶乘结果

    例如:第二次循环的时候,也就是2! 他是等于第一次的阶乘结果 乘一个 当前当前的循环次数也就是2 

               第三次循环的时候,3!= 2! * 3

               第四次循环,          4!=3! * 4

               ...............

    


参考代码:

#include <stdio.h>
int main()
{
	int n;
	long long int sum = 0, t = 1;
	scanf("%d", &n);
	for (int i = 1; i <= n; i++)
	{
		t *= i;
		sum += t;
	}
	printf("%lld", sum);
}


点赞(0)
 

0.0分

65 人评分

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

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

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

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

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

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

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

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

评论列表 共有 25 条评论

cxt 1年前 回复TA
@左右 直接long long int
recce 2年前 回复TA
#include<stdio.h>
int main()
{
    unsigned long long int Aa = 0, Bb = 1;
    int i, o;
    scanf("%d",&o);
    if(o>20){
        return -1;//判断输入,如果大于20直接结束(我发现写的全部都没有写明不能大于20)
    }
    for(i = 1; i <= o; i++){
        Aa = Aa + Bb;
        Bb = (i + 1) * Bb;
    }
    printf("%lld",Aa);
}
日夜无祥 2年前 回复TA
#include <stdio.h>
int main()
{
    int n;
    long long int sum = 0, t = 1;
    scanf("%d", &n);
    for (int i = 1; i <= n; i++)
    {
        t *= i;
        sum += t;
    }
    printf("%lld", sum);
}
SS666 3年前 回复TA
0的阶乘不是1吗?
李李李 3年前 回复TA
@好想进省一 因为20的阶乘数值太大,超过范围了,
王junior 3年前 回复TA
@不是山谷 b的值可能溢出吧
Nvemiy 3年前 回复TA
@左右 还是把double改为long long int吧,还有那个a的值也应该为long long int,它到后面用int也会溢出的
好想进省一 3年前 回复TA
n不超过20是什么意思呢,为什么用long int或者long long int正确,但是用int就会错误呢
不是山谷 3年前 回复TA
#include <stdio.h>
int jiecheng(int a)
{
    int b=1;
    for(int i=1;i<=a;i++){
        b=b*i;
    }
    return b;
}
int main()
{
	long long int n,s=0;
	scanf("%lld",&n);
	s=0;
	for(int i=1;i<=n;i++){
        s=s+jiecheng(i);
	}
	printf("%lld",s);
	return 0;
}
错误50,求问为什么
你tm劈我代码是吧 3年前 回复TA
把int换成long就行了