利用函数的递归调用,求n!

 我来答
糜若雁仁钧
2019-12-16 · TA获得超过2.9万个赞
知道大有可为答主
回答量:1.1万
采纳率:30%
帮助的人:955万
展开全部
是每次调用
hanoi
函数的时候都会从头到尾执行,但是不是每一行都执行。
 
因为
hanoi
函数中有
if
语句。如果当时
n
==
1,就只会执行
if
分支中的
move(one,three);
一句,跳过整个
else
分支。
如果当时
n
!=
1,就会跳过
if
分支,只执行
else
分支里的语句:
{
hanoi(n-1,one,two,three);
move(one,three);
hanoi(n-1,two,one,three);
}
 
希望这样说,你能清晰一点。
 
其实不用害怕递归调用,虽然说调用自己,其实可以看成代码相同的另一个函数。譬如说一开始
n
=
3,你就当作是调用一个叫
hanoi3
的函数,里面只有
else
分支里的三个语句,其中两句是调用
hanoi2。hanoi2
里面也只有
else
分支里的三个语句,其中两句是调用
hanoi1。hanoi1
却是只有
if
分支里的一个语句。
chenxfsoft
2010-12-28 · TA获得超过1380个赞
知道大有可为答主
回答量:2418
采纳率:0%
帮助的人:1847万
展开全部
function et(n as long) as long
if n <=1 then et=1 else et =n*et(n-1)
end function

用法: msgbox et(10)
手写代码,如有手误自查一下.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jzaleph
2010-12-28 · TA获得超过878个赞
知道小有建树答主
回答量:802
采纳率:0%
帮助的人:574万
展开全部
int fun(int n)
{
if((n==1)||(n==0))return 1;
return n*fun(n-1);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hjflyblue
推荐于2016-05-24 · TA获得超过306个赞
知道小有建树答主
回答量:169
采纳率:0%
帮助的人:161万
展开全部
#include <stdio.h>
int fun(int n)
{
if(n==1)return 1;
return n*fun(n-1);
}
int main()
{
int n,sum;
while(scanf("%d",&n)!=EOF)
{
sum=fun(n);
printf("%d\n",sum);
}
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
chaochaolovekk
2010-12-28
知道答主
回答量:1
采纳率:0%
帮助的人:0
展开全部
#include <stdio.h>
int fun(int n)
{
if(n==1)return 1;
return n*fun(n-1);
}
int main()
{
int n,sum;
while(scanf("%d",&n)!=EOF)
{
sum=fun(n);
printf("%d\n",sum);
}
}
凯杰,采我的吧!嘻嘻
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式