解题思路: 首先我们先了解整型家族(字符、短整型、整型、长整型)的变量的最小范围
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分
110 人评分
麻烦大佬们帮我看看 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; }
uq_42565545223 2022-10-15 12:41:00 |
你把上面定义阶乘的两个int全换成long long int,%d改成%lld
大佬们帮忙看看为啥就对了一半 #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; }
菜蛙 2022-07-24 09:59:02 |
#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; }
菜蛙 2022-07-24 10:01:41 |
咋回事,排版又乱了。。fac阶乘函数,用long long声明,我试了下就通过了。还有你最后输出不能回车啊!我栽在输出格式很多回了,哎~
哪位大佬可以帮忙看看这个程序哪里错了,为什么提交后显示是错误的?? #include<stdio.h> //定义阶乘函数计算n! int jiecheng(int x) { int i=1,J=1; while(i<=x) { J=1*i*J; i++; } return J; } int main() { int n; long long int A,Sn; Sn=0; scanf("%d",&n); if(n<=20) { for(int i=1;i<=n;i++) { A=jiecheng(i); Sn=Sn+A; } printf("%lld",Sn); } }
UDmaster 2022-06-26 14:35:46 |
你把上面定义阶乘的两个int全换成long long int就ok了
寻光 2022-06-26 19:12:07 |
你定义的函数类型为int类型,返回值赋给long long int 会有丢失,且定义函数的int j需改为 long long int,因为这是阶乘后的得数会较大,int范围已不够
寻光 2022-06-26 19:12:26 |
#include<stdio.h> //定义阶乘函数计算n! long long int jiecheng(int x) { int i=1; long long int J=1; while(i<=x) { J=1*i*J; i++; } return J; } int main() { int n; long long int A,Sn; Sn=0; scanf("%d",&n); if(n<=20) { for(int i=1;i<=n;i++) { A=jiecheng(i); Sn=Sn+A; } printf("%lld",Sn); } }
寻光 2022-06-26 19:12:56 |
修改后的源码见上面
感谢大佬,提交了四五次没有成功,原来是int字符有限,要用longlong #include<stdio.h> int main() { int n, i; long long an, Sn; scanf("%d", &n); for(i = 1, an = 1, Sn = 0; i <= n; i++){ an = an * i; Sn = Sn + an; //printf("temporal Sn is %d, temporal an is %d\n", Sn, an); } printf("%lld", Sn); return 0; }
#include <stdio.h> long CalData(int num); int main(void) { int num = 0; scanf("%d",&num); long sum = 0; for(int i= 1;i <= num;i++) { sum += CalData(i); } printf("%ld\n" ,sum); } long CalData(int num) { if(num == 0) { return 1; } else { return num * CalData(num - 1); } }
IP判断 (C++代码)浏览:728 |
点我有惊喜!你懂得!浏览:1564 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:773 |
C语言程序设计教程(第三版)课后习题7.2 (Java代码)浏览:694 |
C语言程序设计教程(第三版)课后习题8.9 (C语言代码)浏览:597 |
矩阵乘法 (C++代码)浏览:1662 |
不容易系列2 (C语言代码)浏览:641 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:591 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:818 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:582 |
艾叶 2022-12-18 15:38:44 |
因为函数类型是int 吗?