原题链接:[编程入门]阶乘求和
解题思路: 首先我们先了解整型家族(字符、短整型、整型、长整型)的变量的最小范围


1.因为这是阶乘求和,一般的int 类型可能就不够,因此我们利用long long int 类型(不用unsigned long 因为当n为20时,Sn =2561327494111820313)
了,unsigned long的范围不够。
2.求Sn的和,我·用的是两个for循环嵌套
for (int i = 1; i <= n; i++)
{
j = 1; //要在外面for循环执行完一次就初始化一次,要不就带入了内层for循环的值
for(int m = 0; m < i; m++)
j *= (m + 1); //求出第n个数的n的阶乘
Sn = Sn + j; //依次加上阶乘数
}还可以把我这两个for嵌套变为一个
//借鉴 渴望学到知识的菜鸟 这位博主用的代码
for (int i = 1; i <= n; i++)
{
t *= i;
sum += t;
}注意事项: 可能很多人多把变量的类型设为int类型导致错误,这里是long long int类型比较合适
参考代码:
#include <stdio.h>
int main(void)
{
int n;
long long Sn = 0, j;
scanf("%d", &n);
for (int i = 1; i <= n; i++)
{
j = 1;
for(int m = 0; m < i; m++)
j *= (m + 1);
Sn = Sn + j;
}
printf("%lld", Sn); //long long的格式指定符为%lld
return 0;
}0.0分
82 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
哪有问题啊?? #include<stdio.h> int main() { int n,i,t = 1,s = 0; scanf("%d",&n); for(i = 1;i <= n;i++) { t = t * i; s = s + t; } printf("%d",s); return 0; }#include<stdio.h> int main() { int n; long int A=1; long int Sn=0; scanf("%d",&n); for(int i=1;i<=n;i++) { A=A*i; Sn=Sn+A; } printf("%lld\n",Sn); return 0; }麻烦大佬们帮我看看 int fun(int n) { long long a=1 ; for (int i = 1; i <= n; i++) a = a* i; return a; } int main() { int n; long long sn = 0; scanf("%d", &n); for (int m = 1; m <= n; m++) sn += fun(m); printf("%lld", sn); return 0; }请大佬们帮我看看为什么只对了一半 #include <stdio.h> int main () { int j=1; int answer=1; int N=0; int x=1; int Sn=0; scanf("%d",&N); for(x=1;x<=N;x++){ do{ answer*=j; j++; } while(j<=x); Sn+=answer; } printf("%d",Sn); return 0; }@琴忆忘川空吟殇 #include<stdio.h> long long fac(int n){ if(n == 1){ return 1; }else{ return n*fac(n-1); } } int sum(int n){ long long sum = 0; for(int i=1;i<=n;++i){ sum = sum+fac(i); } return sum; } int main(){ int n; scanf("%d",&n); printf("%lld",sum(n));//printf("%lld ",sum(n)); return 0; }大佬们帮忙看看为啥就对了一半 #include<stdio.h> int fac(int n){ if(n == 1) return 1; return n*fac(n-1); } int sum(int n){ long long sum = 0; for(int i=1;i<=n;++i){ sum = sum+fac(i); } return sum; } int main(){ int n; scanf("%d",&n); printf("%lld\n",sum(n)); return 0; }