本题要求实现一个计算非负整数阶乘的简单函数。

函数接口定义:

int Factorial( const int N );

其中​​N​​​是用户传入的参数,其值不超过12。如果​​N​​​是非负整数,则该函数必须返回​​N​​的阶乘,否则返回0。

裁判测试程序样例:

#include <stdio.h>

int Factorial( const int N );

int main()
{
int N, NF;

scanf("%d", &N);
NF = Factorial(N);
if (NF) printf("%d! = %d\n", N, NF);
else printf("Invalid input\n");

return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

5结尾无空行

输出样例:

5! = 120结尾无空行


int Factorial( const int N )
{
int NF=1;
int i;
while(N>0&&N<=12)
{
for(i=0;i<=12;i++)
{
if(i==0)
{
NF=1;//之前的时候这里写return 1;其实是错的,
}
else
{
NF=NF*i;
}
}
return NF;
}
return 0;//不满足时就返回这个
}