C语言计算y=0!+1!+2!+3!+…n!
时间: 2023-10-06 16:07:08 浏览: 52
可以使用循环和递归两种方式来计算。
循环方式:
```c
#include <stdio.h>
int main() {
int n, i, j, factorial, sum = 0;
printf("请输入n:");
scanf("%d", &n);
for (i = 0; i <= n; i++) {
factorial = 1;
for (j = 1; j <= i; j++) {
factorial *= j;
}
sum += factorial;
}
printf("y=%d\n", sum);
return 0;
}
```
递归方式:
```c
#include <stdio.h>
int factorial(int n) {
if (n == 0) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main() {
int n, i, sum = 0;
printf("请输入n:");
scanf("%d", &n);
for (i = 0; i <= n; i++) {
sum += factorial(i);
}
printf("y=%d\n", sum);
return 0;
}
```
两种方式的思路都是一样的,都是先计算阶乘,然后累加到总和中。只不过循环方式用内层循环计算阶乘,而递归方式则是用递归函数计算。
相关推荐
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)