一、递归的定义
- 方法或函数调用自身的方式称为递归调用,调用称为递,返回称为归。
- 递归是一种非常高效、简洁的编码技巧,应用广泛的算法,比如DFS深度优先搜索、前中后序二叉树遍历等都是使用递归
二、递归的应用
- 1.递归的优缺点
优点:代码的表达力强,简洁
缺点:空间复杂度高,存在重复计算,堆栈溢出
- 2.递归可以解决的问题
1)问题的解可以分解为若干子问题
2)问题与子问题的求解思路一致
3)存在递归终止条件
三、递归的实现
- 1)递归代码
找到将大问题分解为小问题的规律,写出递推公式,然后再推敲终止条件,最后将递推公式和终止条件翻译成代码。
- 2)递归代码的理解
如果一个问题A可以分解为若干个子问题B、C、D,可以假设子问题B、C、D已经解决。而且,你只需要思考问题A与子问题B、C、D两层之间的关系即可
四、递归问题及解决方案
- 警惕堆栈溢出:可以声明一个全局变量来控制递归的深度,从而避免堆栈溢出
- 警惕重复计算:通过某种数据结构来保存已经求解过的值,从而避免重复计算。
例子
假如这里有 n 个台阶,每次你可以跨 1 个台阶或者 2 个台阶,请问走这 n 个台阶有多少种走法?如果有 7 个台阶,你可以 2,2,2,1 这样子上去,也可以 1,2,1,1,2 这样子上去,总之走法有很多,那如何用编程求得总共有多少种走法呢?
我们仔细想下,实际上,可以根据第一步的走法把所有走法分为两类,第一类是第一步走了 1 个台阶,另一类是第一步走了 2 个台阶。所以 n 个台阶的走法就等于先走 1 阶后,n-1 个台阶的走法 加上先走 2 阶后,n-2 个台阶的走法。用公式表示就是:
f(n) = f(n-1)+f(n-2)
n=2 时,f(2)=f(1)+f(0)。如果递归终止条件只有一个 f(1)=1,那 f(2) 就无法求解了。所以除了 f(1)=1 这一个递归终止条件外,我们可以把 f(2)=2 作为一种终止条件,表示走 2 个台阶,有两种走法,一步走完或者分两步来走
f(1) = 1;
f(2) = 2;
f(n) = f(n-1)+f(n-2)