5个回答
推荐于2018-12-12
展开全部
#include <stdio.h>
int Func(int n)
{
if(n < 2)
return 1;
else
return n*Func(n-1);
}
int main()
{
int n = 5;
printf("n! = %d\n",Func(n));
return 0;
}
执行过程:
-》Func(5)
-》5*Func(4)
-》5*(4*Func(3))
-》5*(4*(3*Func(2))))
-》5*(4*(3*(2*Func(1))))
当n为0的时候停止递归,返回结果
由于遇到1的时候返回1,那么Func(1)=1
所以结果是5*(4*(3*(2*1))) = 120
int Func(int n)
{
if(n < 2)
return 1;
else
return n*Func(n-1);
}
int main()
{
int n = 5;
printf("n! = %d\n",Func(n));
return 0;
}
执行过程:
-》Func(5)
-》5*Func(4)
-》5*(4*Func(3))
-》5*(4*(3*Func(2))))
-》5*(4*(3*(2*Func(1))))
当n为0的时候停止递归,返回结果
由于遇到1的时候返回1,那么Func(1)=1
所以结果是5*(4*(3*(2*1))) = 120
2013-10-27
展开全部
int fun(int x)
{
if(x==1)return 1;
else return fun(x-1)*x;
}
void main()
{
printf("%s\n",fun(30));
}
因为n=n*(n-1)!
所以主要思想是这样,如果要求的n值为1,则返回1
否则返回n*(n-1)!
{
if(x==1)return 1;
else return fun(x-1)*x;
}
void main()
{
printf("%s\n",fun(30));
}
因为n=n*(n-1)!
所以主要思想是这样,如果要求的n值为1,则返回1
否则返回n*(n-1)!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
求n的阶乘,递归,参考代码如下:
#include<stdio.h>
double fac(int n)
{
if(n<=1)
return 1;
return fac(n-1)*n;
}
int main()
{
printf("%.0lf",fac(100));
}
#include<stdio.h>
double fac(int n)
{
if(n<=1)
return 1;
return fac(n-1)*n;
}
int main()
{
printf("%.0lf",fac(100));
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-10-27
展开全部
int getn(int n)
{
if (n == 2)
return 2;
else
return n * getn(n-1);
}
{
if (n == 2)
return 2;
else
return n * getn(n-1);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
double JieCheng(double n)
{
if (n <= 1)
{
return 1;
}
return n * JieCheng(n - 1);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询