什么时候使用递归,什么时候使用循环?

最好讲的缜密一些,可以感到他们的区别与联系。... 最好讲的缜密一些,可以感到他们的区别与联系。 展开
 我来答
miniapp3wwC76odT2M2F
2008-10-09 · TA获得超过879个赞
知道小有建树答主
回答量:291
采纳率:0%
帮助的人:259万
展开全部
递归和循环两者完全可以互换。

递归:递归效率低一些,它的运行需要较多次数的函数调用,如果调用层数比较深,需要增加额外的堆栈处理,比如参数传递需要压栈等操作,会对执行效率有一定影响,

但程序容易理解,代码写的少。代码简洁、清晰,并且容易验证正确性。

根据你对程序的效率,以及容易理解性 来综合。

循环:效率高,速度快,结构简单。
但是,有些问题,用循环的话,程序难于编写。也不易理解。

综上所述:循环和递归可以互换。如果用循环可以搞写的话,就尽量用循环。否则如果用递归容易理解,而程序本身对效率的要求也不是很高的话,就用递归。

根据本人的经验写的,希望能帮到你。
yl_ls
2008-10-09 · TA获得超过459个赞
知道小有建树答主
回答量:409
采纳率:0%
帮助的人:419万
展开全部
递归,是用在一种需要深度计算中的方式
比如在树中查找一个节点,因为每个节点只知道他的子级节点,而子级节点知道孙节点,所以在循环查找当前节点的所有子节点之上,需要深度循环查找每个子节点的子节点,这就成为一个递归
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cnbf
2008-10-17 · TA获得超过354个赞
知道小有建树答主
回答量:441
采纳率:0%
帮助的人:0
展开全部
用递归的地方都能用循环, 只要尽量少用递归就行了. 因为递归的效率低.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友832f67911
2008-10-09 · 超过14用户采纳过TA的回答
知道答主
回答量:41
采纳率:0%
帮助的人:43.6万
展开全部
楼上的回答非常全面了,如果你循环熟练地话,可以取消递归
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友638b535
2008-10-09 · TA获得超过234个赞
知道小有建树答主
回答量:268
采纳率:0%
帮助的人:330万
展开全部
递归与循环是两种不同的解决问题的典型思路。

递归算法:

优点:代码简洁、清晰,并且容易验证正确性。(如果你真的理解了算法的话,否则你更晕)

缺点:它的运行需要较多次数的函数调用,如果调用层数比较深,需要增加额外的堆栈处理,比如参数传递需要压栈等操作,会对执行效率有一定影响。但是,对于某些问题,如果不使用递归,那将是极端难看的代码。

循环算法:

优点:速度快,结构简单。

缺点:并不能解决所有的问题。有的问题适合使用递归而不是循环。如果使用循环并不困难的话,最好使用循环。

递归算法 和循环算法总结
1. 一般递归调用可以处理的算法,也通过循环去解决常需要额外的低效处理 。
2. 现在的编译器在优化后,对于多次调用的函数处理会有非常好的效率优化,效率未必低于循环。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式