递归算法(LeetCode基础)

递归算法

简介

递归三原则:

1.确定基本情况

2.不断改变状态并向基本情况靠近

3.不断调用自身函数

递归 = 递推过程+回归过程

应用

01斐波那契数列

#斐波那契数列
def fibo(n):
    #如果设置成if n == 1 or n == 2注意是or的关系,不是and关系,否则,系统会栈溢出
    
    if n == 0 :
        return 0
    elif n == 1:
        return 1
    else:
        return fibo(n-1)+fibo(n-2)

斐波那契数列的问题:

​ 递归过程存在重复计算问题

解决方案:

​ 将已经计算过的结果存放在哈希缓存表中

在这里插入图片描述

def fibo(n,cach={}):
    if n < = 1:
        return 0							#在函数中,我们首先检查是否已经计算过这个位置的结果
    elif n in cache:
        return cache[n]						#如果是,则直接从缓存 cache 中返回结果。
    else:
        result = fibo(n-1)+fibo(n-2)
        cache[n] = result					#如果不是,则使用递归的方式计算,并将计算结果保存到缓存中,再返回结果。
        return result
    										#这样就避免了重复计算。

02二叉树的最大深度

class TreeNode:
    def __init__(self,value=0):
        self.key = value
        self.left = None
        self.right = None
        
class Solution:
    def maxDepth(self,root:Optional[TreeNode]) -> int:
        if not root:
            return 0
        return max(self.maxDepth(root.left) + self.maxDepth(root.right)) + 1   
    	#调用maxDepth函数时加上self,left和right加上root而不是self

练习

爬楼梯问题

def climbStair(num):
    if num == 1 or num == 0:
        return 1
    else:
        return climbStair(num-1) + climbStair(n-2)

⚠️笔者最近忙于复习,准备考试,测试结果一项留待考试后完善

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sean7566

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值