递归

递归

重复将问题分解为同类的子问题而解决问题的办法,表现为函数调用函数本身。

需要满足的三个条件

  1. 一个问题可以分解为几个子问题的解
  2. 这个问题和子问题除了数据规模,求解思路完全一样
  3. 存在递归终止条件

如何编写递归代码?

写递归代码的关键就是找到如何将大问题分解为小问题的规律,并且基于此写出递推公式,然后再推敲终止条件,最后将递推公式和终止条件翻译成代码。
如果一个问题 A 可以分解为若干子问题 B、C、D,你可以假设子问题 B、C、D 已经解决,在此基础上思考如何解决问题 A。而且,你只需要思考问题 A 与子问题 B、C、D 两层之间的关系即可,不需要一层一层往下思考子问题与子子问题,子子问题与子子子问题之间的关系。屏蔽掉递归细节,这样子理解起来就简单多了。因此,编写递归代码的关键是,只要遇到递归,我们就把它抽象成一个递推公式,不用想一层层的调用关系,不要试图用人脑去分解递归的每个步骤。

递归代码要警惕堆栈溢出

函数调用会使用栈来保存临时变量。每调用一个函数,都会将临时变量封装为栈帧压入内存栈,等函数执行完成返回时,才出栈。系统栈或者虚拟机栈空间一般都不大。如果递归求解的数据规模很大,调用层次很深,一直压入栈,就会有堆栈溢出的风险。

递归代码要警惕重复计算

当前问题下的子问题,可能在其他问题下的子问题下也进行了计算,这样就导致重复计算。


递归
https://www.zengzx.xyz/2019/04/17/01.知识架构/数据结构和算法/递归/
作者
Eden
发布于
2019年4月17日
许可协议