求1!+2!+3!+......+20!的和c语言
时间: 2023-11-22 21:50:03 浏览: 75
以下是求1!+2!+3!+......+20!的和的C语言代码:
```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!+......+20!的和,并将结果存储在双精度浮点型变量sum中。在每次循环中,使用temp变量来计算阶乘,并将其加到sum中。最后,使用printf函数输出结果,注意输出的格式。
相关问题
3.用c语言求1! +2!+ 3!+4!+...+ 20!
在C语言中,计算阶乘是一个常见的数学运算。为了求从1到20的所有整数的阶乘之和,我们需要编写一个循环,递归地计算每个数字的阶乘,并累加它们。这里是一个简单的示例:
```c
#include <stdio.h>
unsigned long long factorial(int n) {
if (n == 0 || n == 1) // 阶乘的基本情况,0和1的阶乘都是1
return 1;
else
return n * factorial(n - 1); // 递归计算阶乘
}
int main() {
unsigned long long sum = 0; // 初始化阶乘和为0
for (int i = 1; i <= 20; i++) {
sum += factorial(i);
}
printf("1! + 2! + 3! + ... + 20! 的和是 %llu\n", sum);
return 0;
}
```
这个程序首先定义了一个`factorial`函数,用于计算阶乘。然后在主函数里,我们通过一个for循环依次累加从1到20的每个数的阶乘。最后打印出结果。
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`数据类型来存储结果,因为阶乘的结果会很快变得非常大。
阅读全文