百科问答小站 logo
百科问答小站 font logo



递归和循环相比耗费更多的空间,对于循环来说除了可以简化逻辑外还有什么优点吗? 第1页

  

user avatar   zhai-sen-8 网友的相关建议: 
      

比如说dp,一种实现方式就是自底向上的循环,另一种实现方式是自顶向下的memoization(用递归)。关键就在于,如果使用循环来实现,就要自己确定遍历次序,但memoization是自动遍历的,不需要你亲自确定次序。很多时候,要想自己确定遍历次序是很困难的,甚至是几乎做不到的;即使可以做到,遍历的顺序也未必和memoization一样。如果循环的遍历顺序更差(意思是重复遍历的很多),那么时间上就不如递归。(我听人说过在一种背包问题中循环的时间大概长了30%)

举个例子,我之前看过的回答,计算斐波那契数列的一种比较快速的算法是利用如下的递推式:

写个memoization的递归是容易的。但想想如何自底向上循环?直接从小到大往上循环可是 的。




  

相关话题

  为什么多数编程语言的赋值在左边?是有什么历史渊源吗? 
  Linux 图形界面的显示原理是什么? 
  Java对于int变量a,如何以最快速度计算34*a? 
  程序员有哪些借口可以让自己写出低质量的代码? 
  Java中有哪些设计精良的部分(精华),还有哪些是不值得花费很多时间探究的知识点? 
  你见过哪些令你瞠目结舌的 Python 代码技巧? 
  C++ 中,如果指针换了被指向的东西,那被指向的原来的东西(是被 new 出来的)所占的内存会立刻被释放吗? 
  红芯浏览器真的自带了假的证书用以监控 HTTPS 内容吗? 
  做主程序员是怎样的体验? 
  vscode是用什么语言写出来的?为什么华为能做出鸿蒙系统,却开发不出类似vscode的开发工具? 

前一个讨论
如何评价在 LG 杯 16 强赛上,柯洁战胜申真谞,在世界第一人之争中再下一城?
下一个讨论
作曲技术理论发展到极致,将会变成一种怎样的形态?





© 2025-01-18 - tinynew.org. All Rights Reserved.
© 2025-01-18 - tinynew.org. 保留所有权利