题目描述 求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字。 输入 n(n <= 10) 输出 和
时间: 2023-11-09 17:00:13 浏览: 739
首先,根据题目描述,我们需要求解Sn=1! 2! 3! 4! 5! … n!之值。可以使用循环和累加的方法来求解,具体实现代码如下:
```python
n = int(input())
s = 0
f = 1
for i in range(1, n+1):
f *= i
s += f
print(s)
```
相关问题
用c语言题目描述 求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字。
以下是使用C语言计算Sn=1!+2!+3!+4!+5!+…+n!的代码:
```c
#include <stdio.h>
int main() {
int n, i, j;
long long fact, sum = 0;
printf("请输入一个数字:");
scanf("%d", &n);
for (i = 1; i <= n; i++) {
fact = 1;
for (j = 1; j <= i; j++) {
fact *= j;
}
sum += fact; }
printf("Sn的值为:%lld", sum);
return 0;
}
```
题目描述:求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字。
题目描述:求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字。
解题思路:
1.使用一层for循环,从低位到高位的累加,用sum保存,直至n。
2.使用递归函数计算每个数的阶乘,使用一个for循环计算阶乘数的累加,逐步累加每个数阶乘的结果到总结果中。
3.双层for循环,时间复杂度n*n,不建议使用。
参考代码:
//for循环解决方法
#include<iostream>
using namespace std;
int main(){
int n;
long s=1,sum=0;
cin>>n;
for(int i=1;i<=n;i++){
s*=i;
sum+=s;
}
cout<<sum;
return 0;
}
//递归的方法
#include<iostream>
using namespace std;
long fun(int n){
if(n==1) return 1;
else{
return n*fun(n-1);
}
}
int main(){
int n;
long sum=0;
cin>>n;
for(int i=1;i<=n;i++){
sum+=fun(i);
}
cout<<sum<<endl;
return 0;
}
阅读全文