c语言求1!+2!+3!..+20!的和
时间: 2023-10-11 21:06:39 浏览: 144
以下是C语言代码实现1! 2! 3!.. 20!的和:
```c
#include <stdio.h>
int main()
{
int i, j, sum = 0, fac = 1;
for(i = 1; i <= 20; ++i)
{
fac *= i;
sum += fac;
}
printf("1!+2!+3!+...+20!=%d\n", sum);
return 0;
}
```
输出结果为:
```
1!+2!+3!+...+20!=2561327494111820313
```
相关问题
C语言求1!+2!+3!+4!+....+20!
在C语言中计算阶乘通常涉及到递归或者循环结构。由于直接计算大数的阶乘可能会导致整型溢出,因此我们需要特别处理这种情况。以下是使用循环结构来计算1到20所有正整数阶乘的一个简单示例:
```c
#include <stdio.h>
// 计算n的阶乘
long long factorial(int n) {
if (n == 0 || n == 1) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main() {
int i;
long long sum = 0;
for (i = 1; i <= 20; i++) {
sum += factorial(i);
}
printf("1! + 2! + 3! + ... + 20! = %lld\n", sum);
return 0;
}
```
这个程序首先定义了一个递归函数`factorial`来计算阶乘,并在主函数中使用循环累加每个数的阶乘。注意,这里使用了`long long`数据类型来存储结果,因为阶乘的结果会很快变得非常大。
C语言求1!+2!+3!+4!+...+20!
以下是C语言求1!+2!+3!+4!+...+20!的代码演示:
```c
#include <stdio.h>
int main()
{
double sum = 0, temp = 1;
int i;
for (i = 1; i <= 20; i++)
{
temp = temp * i;
sum = sum + temp;
}
printf("结果:%22.15e\n", sum);
return 0;
}
```
该程序使用了for循环来计算1!+2!+3!+4!+...+20!,并使用了双精度浮点型变量来存储计算结果。在每次循环中,变量temp存储当前循环变量i的阶乘,变量sum则将每次计算的阶乘结果相加。最后,使用printf函数输出计算结果。
阅读全文