解题思路:

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

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


类型名称            字节数    取值范围
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 条评论

uq_78464559451 3年前 回复TA
真的简单粗暴
渴望学到知识的菜鸟 3年前 回复TA
@假应怜 一起加油!
假应怜 3年前 回复TA
嗯嗯 。 没有注意到“溢出”的问题 ,感谢点拨
渴望学到知识的菜鸟 3年前 回复TA
@wangbn 谢谢谢!!!
wangbn 3年前 回复TA
牛逼