递归求阶乘和

社会主义新天地 提交于 2019-12-02 11:45:25

函数fact应返回n的阶乘。函数sum应返回 1!+2!+…+n! 的值。

#include<stdio.h>

int fact(int n);//求单个数的的阶乘
int sum(int n);

int main()
{
    int n;
    scanf("%d", &n);
    printf("%d", sum(n));
    return 0;
}
int fact(int n)
{
    if (n == 1 || n == 0)//0的阶乘也是1
        return 1;
    else
        return n * fact(n - 1);
}

int sum(int n)
{
    if (n == 0)
        return 0;
    if (n == 1)
        return fact(n);
    else
        return fact(n) + sum(n - 1); //fact(n)就是计算当前n的阶乘,sum是计算下一个的数的阶乘往后的和
}

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!