开发者社区> 问答> 正文

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

最好讲的缜密一些,可以感到他们的区别与联系。

展开
收起
知与谁同 2018-07-21 14:36:23 4038 0
5 条回答
写回答
取消 提交回答
  • Nothing for nothing.
    用递归的地方都能用循环, 只要尽量少用递归就行了. 因为递归的效率低.
    2019-07-17 22:54:58
    赞同 展开评论 打赏
  • 递归就是用循环实现的啊~~
    可能你不太了解什么叫递归吧~
    2019-07-17 22:54:58
    赞同 展开评论 打赏
  • 云栖社区聚能聊、问答管理员~发福利、搞怪,八卦我来,论技术、发话题、写博客你上!
    递归,是用在一种需要深度计算中的方式
    比如在树中查找一个节点,因为每个节点只知道他的子级节点,而子级节点知道孙节点,所以在循环查找当前节点的所有子节点之上,需要深度循环查找每个子节点的子节点,这就成为一个递归
    2019-07-17 22:54:58
    赞同 展开评论 打赏
  • 递归和循环两者完全可以互换。

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

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

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

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

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

    根据本人的经验写的,希望能帮到你。
    2019-07-17 22:54:58
    赞同 展开评论 打赏
  • 递归与循环是两种不同的解决问题的典型思路。

    递归算法:

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

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

    循环算法:

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

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

    递归算法 和循环算法总结
    1. 一般递归调用可以处理的算法,也通过循环去解决常需要额外的低效处理 。
    2. 现在的编译器在优化后,对于多次调用的函数处理会有非常好的效率优化,效率未必低于循环。

    -------------------------

    楼上的回答非常全面了,如果你循环熟练地话,可以取消递归

    2019-07-17 22:54:58
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载