蒜术师给了一个正整数 n,让你求出不大于 n 的正整数的阶乘的和(即求 1!+2!+3!+...+n!1!+2!+3!+...+n!)。
时间: 2023-11-17 11:01:47 浏览: 80
给定正整数n,求不大于n的正整数的阶乘的和(即求1!+2!+3!+...+n!)。
以下是代码实现:
```c++
int n;
int sum = 0;
cin >> n;
for (int i=n;i>0;--i){
int x = 1; //存放i阶乘
for(int j=i;j>0;--j){
x*=j;
}
sum+=x;//该操作做了n+n-1+***+3+2+1次
}
cout<<sum<<endl;
```
相关问题
c:蒜术师给了一个正整数 n,让你求出不大于 n 的正整数的阶乘的和(即求 1!+2!+3!+...+n!1!+2!+3!+...+n!)。
以下是使用C语言求解不大于n的正整数阶乘和的代码示例:
```c
#include <stdio.h>
int main() {
int n;
int sum = 0;
scanf("%d", &n);
for (int i = n; i > 0; --i) {
int x = 1; // 存放i的阶乘
for (int j = i; j > 0; --j) {
x *= j;
}
sum += x;
}
printf("%d\n", sum);
return 0;
}
```
该代码首先读取输入的正整数n,然后使用两个嵌套的循环计算每个正整数的阶乘,并将其累加到sum变量中。最后,输出sum的值作为阶乘的和。
用Python代码写给定正整数n,求不大于n的正整数的阶乘的和(即求1! +2! +3! +...+n!输入:一个正整数n (1<n<12) 输出: 不大于n的正整数的阶乘的和。
好的,我来给您写一段代码:
```python
n = int(input("请输入一个正整数n:"))
sum = 0
factorial = 1
for i in range(1, n+1):
factorial *= i
sum += factorial
print("不大于n的正整数的阶乘的和为:", sum)
```
这段代码首先让用户输入一个正整数n,然后使用一个for循环,从1到n遍历每个正整数。在循环体中,计算当前正整数的阶乘,并将其加到一个变量sum中。最后输出sum即可。
需要注意的是,当n比较大时,阶乘的值很容易溢出。因此,这段代码只适用于比较小的n值。
阅读全文