赞
踩
#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! = 1 f=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值的基础上再乘以n
return (f); //返回值f是n!的值
}
运行结果
补充一组用python求阶乘的代码,可以对比一下
#递归实现阶乘
def f(n):
if n==1:
return 1
else:
return n*f(n-1)
f(5)
#不用递归方式实现阶乘
def f(n):
s=1
for i in range(1,n+1):
s=i*s
return s
f(5)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。