标题:[求助]请教一道递归函数的题目
取消只看楼主
inku
Rank: 1
等 级:新手上路
帖 子:122
专家分:0
注 册:2006-8-6
 问题点数:0 回复次数:4 
[求助]请教一道递归函数的题目
fun(int x)
{ if(x/2>0) fun(x/2-2);
printf("%d",x);
}
main()
{ fun(20);
printf("\n");
}
程序的运行结果是 -1 2 8 20
fun(20)=fun(8)=fun(2)
然后怎么办?


搜索更多相关主题的帖子: 递归 函数 fun printf 
2006-10-06 15:12
inku
Rank: 1
等 级:新手上路
帖 子:122
专家分:0
注 册:2006-8-6
得分:0 
f(-1);时(-1/2)<0,应该已经跳出循环了才对.怎么还会执行f(-1)这步呢?
2006-10-06 19:39
inku
Rank: 1
等 级:新手上路
帖 子:122
专家分:0
注 册:2006-8-6
得分:0 
关于f(-1)执行的问题我已经搞懂,可是为什么要一层层出呢?我觉得输出-1是不是就应该结束了呢?
2006-10-06 20:58
inku
Rank: 1
等 级:新手上路
帖 子:122
专家分:0
注 册:2006-8-6
得分:0 

没人能回答我吗?

2006-10-06 22:12
inku
Rank: 1
等 级:新手上路
帖 子:122
专家分:0
注 册:2006-8-6
得分:0 
以下是引用nuciewth在2006-10-6 23:32:51的发言:

但f(-1)这个函数并没有结束的.

明白了,谢谢!

2006-10-06 23:43



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-94500-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.143917 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved