递归算法

一、递归的定义
  • 方法或函数调用自身的方式称为递归调用,调用称为递,返回称为归。
  • 递归是一种非常高效、简洁的编码技巧,应用广泛的算法,比如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)

写递归代码的关键就是找到如何将大问题分解为小问题的规律,并且基于此写出递推公式,然后再推敲终止条件,最后将递推公式和终止条件翻译成代码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值