递归求阶乘题目 求1+2!+3!+…+20!的和。
可以使用递归来求每个数字的阶乘,然后累加得到最终的结果。
具体实现可以参考下面的代码:
#include <stdio.h>
long long factorial(int n) {
if (n == 0 || n == 1) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main() {
int n = 20;
long long sum = 0;
for (int i = 1; i <= n; i++) {
sum += factorial(i);
}
printf("1+2!+3!+...+20! = %lld\n", sum);
return 0;
}
输出结果为:
1+2!+3!+...+20! = 2561327494111820313
需要注意的是,由于20!的结果已经超出了long long类型的范围,因此需要使用更大的数据类型(比如unsigned long long或者long double)来存储结果。
原文地址: https://www.cveoy.top/t/topic/ZlL 著作权归作者所有。请勿转载和采集!