可以使用递归来求每个数字的阶乘,然后累加得到最终的结果。

具体实现可以参考下面的代码:

#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)来存储结果。

递归求阶乘题目 求1+2!+3!+…+20!的和。

原文地址: https://www.cveoy.top/t/topic/ZlL 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录