编写程序,给定正整数n,求不大于n的正整数的阶乘的和(即求1!+2!+3!+...+n!)注意3!=1*2*3。
时间: 2023-11-15 19:02:18 浏览: 275
可以使用循环来计算每个数的阶乘,并将它们相加。以下是一个示例代码:
```
#include <stdio.h>
int main() {
int n, i, j, factorial, sum = 0;
printf("请输入一个正整数n:");
scanf("%d", &n);
for (i = 1; i <= n; i++) {
factorial = 1;
for (j = 1; j <= i; j++) {
factorial *= j;
}
sum += factorial;
}
printf("1!+2!+3!+...+%d! = %d\n", n, sum);
return 0;
}
```
在这个程序中,我们使用了两个循环。外部循环从1到n遍历每个数字,内部循环计算每个数字的阶乘。我们使用变量factorial来存储每个数字的阶乘,并将它们相加到变量sum中。最后,我们输出结果。
相关问题
给定正整数n,求不大于n的正整数的阶乘的和(即求1!+2!+3!+...+n!)
可以使用循环来计算不大于n的正整数的阶乘的和。具体步骤如下:
1. 初始化变量sum为。
2. 使用循环从1到n遍历每个正整数i。
3. 在循环中,计算i的阶乘,并将其加到sum中。
4. 循环结束后,sum即为不大于n的正整数的阶乘的和。
代码如下:
sum =
factorial = 1
for i in range(1, n+1):
factorial *= i
sum += factorial
print(sum)
C++给定正整数n,求不大于n的正整数的阶乘的和(即求1!+2!+3!+...+n!)
```c++
#include <iostream>
using namespace std;
int main() {
int n;
cin >> n;
int sum = 0;
int s = 1;
for (int i = 1; i <= n; i++) {
s *= i;
sum += s;
}
cout << sum << endl;
return 0;
}
```