递归

递归的三大要素

第一要素:明确你这个函数想要干什么

第二要素:寻找递归结束条件
所谓递归,就是会在函数内部代码中,调用这个函数本身,所以,我们必须要找出递归的结束条件,不然的话,会一直调用自己,进入无底洞。也就是说,我们需要找出当参数为啥时,递归结束,之后直接把结果返回,请注意,这个时候我们必须能根据这个参数的值,能够直接知道函数的结果是什么。

第三要素:找出函数的等价关系式
第三要素就是,我们要不断缩小参数的范围,缩小之后,我们可以通过一些辅助的变量或者操作,使原函数的结果不变。

案例:小青蛙跳台阶

一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。

要素一:递归函数功能
求跳上n级台阶共有多少总跳法
要素二:递归结束条件
当n=1时,有一种跳法。当n=2时,有两种跳法。
要素三:函数的等价关系式
当青蛙跳到第n级时,它可以是从第n-1级跳上来的,也可能是从n-2跳上来的。所以f(n)=f(n-1)+f(n-2)

递归的优化

在递归中可能存在大量重复的计算,可以使用空间换时间的方法,将求结果的值保存起来,下次用的时候判断一下是否计算过,如果计算过则直接使用,不需要重新计算。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值