解题思路:
首先我们先了解整型的变量的最小范围
1.因为这是阶乘求和,一般的int 类型可能就不够,因此我们利用long long int 类型了,unsigned long的范围不够。
2.求Sn的和,我用的是两个for循环
还可以把我这两个for变为一个
(这里借了渴望学到知识的菜鸟的代码)
注意事项:
可能很多人多把变量的类型设为int类型导致错误,这里是long long int类型比较合适。
参考代码:
/*
求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字(n不超过20)。
*/
#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);
return 0;
}
0.0分
0 人评分
C语言训练-素数问题 (C语言代码)浏览:1695 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:641 |
这可能是一个假的冒泡法浏览:1071 |
【偶数求和】 (C语言代码)浏览:674 |
简单的a+b (C语言代码)浏览:641 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:485 |
三角形 (C++代码)记忆化搜索浏览:1317 |
简单的a+b (C语言代码)浏览:529 |
循环入门练习5 (C语言代码)浏览:907 |
模拟计算器 (C++代码)浏览:885 |