解题思路: 首先我们先了解整型家族(字符、短整型、整型、长整型)的变量的最小范围
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 人评分
看看吧,对一半 #include<stdio.h> int c[100]={1}; int factorial(int a) { if(c[a]!=0)return c[a]; else { c[a]=c[a-1]*a; return c[a]; } } int main() { int n; scanf("%d",&n); int sum=0; for(int i=1;i<=n;i++) { int b=factorial(i); sum+=b; } printf("%d",sum); return 0; }
#include <stdio.h> int jiecheng(int x) { int i, result = 1; for (i = 1; i <= x; i++) { result *= i; } return result; } int main() { int Sn, n; scanf("%d", &n); for (; n >= 1; n--) { Sn+= jiecheng(n); } printf("%d ", Sn); return 0; } 这个代码输入5,输出153,但还是不对
insane 2024-11-13 21:49:26 |
n=20时Sn范围超了,你用long long int就行
#include <stdio.h> int main() { int i,z,n; long long s=0,j=1; scanf("%d",&n); z=n-1; for(i=1;i<n+1;i++,z--) { j=j*(n-z); s=s+j; } printf("%lld",s); return 0; }
#include<stdio.h> int fac(int num); int main() { int n,sn=0; scanf("%d",&n); for(int i=1;i<=n;i++) { sn = sn + fac(i); } printf("%d",sn); return 0; } int fac(int num) { int product = 1; while(num!=0) { product = product * num; num--; } } 有没有大佬帮忙看一下这个为什么错了
南柯一梦 2024-08-07 10:22:40 |
把变量的类型设为int类型导致错误,是long long int类型比较合适
#include<stdio.h> int main(void) { int n; long long int j=1; long long int sum=0; scanf("%d",&n); for(int i=1;i<=n;i++){ j=j*i; sum=sum+j; } printf("%lld",sum); return 0; }
#include<stdio.h> int main(){ int n; int Sn=0; scanf("%d",&n); for(int i=1;i<=n;i++) { int an=1; for(int j=1;j<=i;j++) { an=an*j; } Sn=Sn+an; } printf("%d",Sn); return 0; } 个位大佬谁帮我看看为啥只有50分啊啊啊啊
#include<iostream> using namespace std; //求Sn = 1!+ 2!+ 3!+ 4!+ 5!+ … + n!之值,其中n是一个数字(n不超过20)。 int main() { int n = 1; cin >> n; int Sn = 0; for (int j = 1; j <= n; j++) { int prod = 1; for (int i = 1; i <=j; i++) { prod *= i; } Sn += prod; } cout << Sn << endl; }求大佬,我的代码哪里错了,为什么只有50分
鱼香墨禾子 2024-03-26 12:05:33 |
j应该是long long?
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> int main() { int a; void j(int x); scanf("%d",&a); if (a >= 0 || a <= 20) j(a); return 0; } void j(int x) { double c = 0; for (int i = 1; i <= x; i++) { double b = 1; for (int k = 1; k <= i; k++) { b *= k; } c += b; } printf("%.0lf", c); } 求大佬解惑,这个为什么错了,明明输出的答案都是对的啊?
maple 2024-03-21 18:36:22 |
#include<iostream> using namespace std; //求Sn = 1!+ 2!+ 3!+ 4!+ 5!+ … + n!之值,其中n是一个数字(n不超过20)。 int main() { int n = 1; cin >> n; int Sn = 0; for (int j = 1; j <= n; j++) { int prod = 1; for (int i = 1; i <=j; i++) { prod *= i; } Sn += prod; } cout << Sn << endl; }求大佬,我的哪里错了,结果运行是对的,但是是50分