求1!+2!+…+20!,其中x!=1*2*…*x,表示阶乘。 输入说明: 输入一个大于3,+小于等于20的整数N 输出说明: 输出从1!+2!+3!+...+N!的和
时间: 2023-11-24 16:51:29 浏览: 85
以下是求1!+2!+…+20!的代码实现:
```c
#include <stdio.h>
long long factorial(int n) { // 定义一个函数用于计算阶乘
long long result = 1;
for (int i = 1; i <= n; i++) {
result *= i;
}
return result;
}
int main() {
int n;
long long sum = 0;
printf("请输入一个大于3且小于等于20的整数N:");
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
sum += factorial(i); // 求1!+2!+3!+...+N!的和
}
printf("1!+2!+3!+...+%d!的和为:%lld\n", n, sum);
return 0;
}
```
相关问题
求阶乘 求1!+2!+…+20!,其中x!=1*2*…*x,表示阶乘。 输入说明:输入一个大于3,+小于等于20的整数N 输出说明:输出从1!+2!+3!+...+N!的和
求阶乘是指将一个正整数n的所有小于等于n的正整数相乘,得到的积就是n的阶乘,用符号n!表示。例如,5! = 5 × 4 × 3 × 2 × 1 = 120。
要求1!+2!+…+20!的和,可以使用循环结构和递归结构来实现。其中,循环结构可以使用for循环或者while循环,递归结构可以使用递归函数来实现。
以下是使用循环结构实现的代码示例:
#include <stdio.h>
int main() {
int n;
long long sum = 0, fac = 1;
printf("请输入一个大于3且小于等于20的整数N:");
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
fac *= i;
sum += fac;
}
printf("1!+2!+...+%d!的和为:%lld\n", n, sum);
return 0;
}
以下是使用递归结构实现的代码示例:
#include <stdio.h>
long long factorial(int n) {
if (n == 1) {
return 1;
}
return n * factorial(n - 1);
}
int main() {
int n;
long long sum = 0;
printf("请输入一个大于3且小于等于20的整数N:");
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
sum += factorial(i);
}
printf("1!+2!+...+%d!的和为:%lld\n", n, sum);
return 0;
}
求阶乘 求1!+2!+…+20!,其中x!=1*2*…*x,表示阶乘。 输入说明: 输入一个大于3,+小于等于20的整数N 输出说明: 输出从1!+2!+3!+...+N!的和
这是一个计算1!+2!+...+N!的程序。其中N是用户输入的一个大于3且小于等于20的整数。程序使用for循环计算每个i的阶乘,并将它们相加得到总和。具体来说,当i=1时,m=1,sum=1;当i=2时,m=1×2,sum=1+1×2;当i=3时,m=1×2×3,sum=1+1×2+1×2×3;i=4时,m=1×2×3×4,sum=1+1×2+1×2×3+1×2×3×4;以此类推。最后,程序输出总和。
代码实现如下:
```
#include <stdio.h>
int main(void) {
int n = 0;
int i = 0;
int m = 1;
int sum=0;
printf("请输入n的值:");
scanf("%d", &n);
for (i=1; i<=n; ++i) {
m = m * i;
sum = sum +m;
}
printf ("1!+2!+...+%d! = %d\n", n, sum);
return 0;
}
```
阅读全文