#include <stdio.h> //包含标准库的信息int main(void) //每个程序都从main函数的起点开始执行
{ //函数开始int p = 1;int n;printf("请输入所求阶乘:\n");scanf("%d",&n);for (int i = 2; i <= n ; ++i) {p = p * i;}printf("%d! = %d",n,p);return 0;
} //函数结束
运行结果
法二、函数调用
#include <stdio.h> //包含标准库的信息
int main(void) //每个程序都从main函数的起点开始执行
{int fac(int n); //函数声明int n ,y;printf("input an integer number:");scanf("%d",&n); //输入要求阶乘的数y = fac(n);printf("%d!=%d\n",n,y);return 0;
}
int fac(int n) //定义fac函数
{int f;if(n<0) //不能求0以下的阶乘printf("n<0,data errot!");else if(n == 0||n==1) //n=0或1时,n! = 1f=1;else f=fac(n-1)*n; //n>1时,n! = n * (n - 1)return (f);
}
运行结果
三、输出1到5的阶乘值
#include <stdio.h> //包含标准库的信息
int main(void) //每个程序都从main函数的起点开始执行
{int fac(int n); //函数声明for (int i = 1; i <= 5; ++i) { //先后5次调用fac函数printf("%d! = %d\n",i,fac(i)); //每次计算并输出i!的值}return 0;
}
int fac(int n)
{static int f = 1; //定义静态局部变量,f保留了上次调用结束时的值f = f * n; //在上次f值的基础上再乘以nreturn (f); //返回值f是n!的值
}
运行结果
补充一组用python求阶乘的代码,可以对比一下
#递归实现阶乘
def f(n):if n==1:return 1else:return n*f(n-1)
f(5)
#不用递归方式实现阶乘
def f(n):s=1for i in range(1,n+1):s=i*sreturn s
f(5)