小提示:
看本文之前,可以先看一下文章:“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;//可有可无,建议添加,不影响程序运行
}
代码运行结果
写在最后:
读两遍下来,如果仍然有不清楚的地方,可在评论区留言。
如果你有其他感到困惑的问题,欢迎在评论区留言,让我看到你的问题哦。