C语言通过递归算法求n的阶乘(1.2)

小提示:

        看本文之前,可以先看一下文章:C++通过递归算法求n的阶乘(1.1),阶乘概念、递归算法分析、编程分析在其中查看,之后再看本文可以更好的理解。

        如果具备知识基础,则可以直接看代码。

代码实现

        代码实现如下所示:

//导入头文件
#include<stdio.h>

//创建factorial函数(用于计算)
int factorial(int n){
    int fact;//记录值
    if(n==0){
        fact=1; //考虑到特殊情况 0!=1,因此初始值赋为1
    }
    else{
        fact=factorial(n-1)*n; //递归计算并记录累积值
    }
    return fact;//返回值
}


//说明:本文代码编译环境为DevC++。
int main(){
    int n;
    int fact;//接收结果
    printf("请输入要求阶乘的正整数:");
    scanf("%d",&n);
    fact=factorial(n);//计算
    printf("%d的阶乘为:%d!=%d",n,n,fact);//输出的时候“!”不能忘记哦
    printf("\n");//换行
    return 0;//可有可无,建议添加,不影响程序运行
}

代码运行结果

                

写在最后:

        读两遍下来,如果仍然有不清楚的地方,可在评论区留言。

        如果你有其他感到困惑的问题,欢迎在评论区留言,让我看到你的问题哦。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

等日出看彩虹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值