在C语言中用递归调用的方法求n!

请“老师”把过程详细的写的下,在解释一下。谢谢谢谢谢谢非常之感谢。... 请“老师”把过程详细的写的下,在解释一下。谢谢 谢谢 谢谢 非常之感谢。 展开
 我来答
匿名用户
推荐于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
匿名用户
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)!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cylz0703
2018-12-20 · TA获得超过3.4万个赞
知道大有可为答主
回答量:1.8万
采纳率:83%
帮助的人:4359万
展开全部
求n的阶乘,递归,参考代码如下:
#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);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
璐人钇
2018-04-24 · TA获得超过1552个赞
知道小有建树答主
回答量:1365
采纳率:69%
帮助的人:657万
展开全部
double JieCheng(double n)
{
    if (n <= 1)
    {
        return 1;
    }
    
    return n * JieCheng(n - 1);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式