当前位置: 首页 > news >正文

每天五分钟:leetcode动态规划-递归与递推_day2

0)先记住一句话(贯穿两种写法)

到第n阶的方法数:

  • 最后一步要么走 1 阶:从n-1

  • 要么走 2 阶:从n-2

所以永远是:

f(n) = f(n-1) + f(n-2)


1)递归版本(从“大问题”往下问“小问题”)

✅ 1.1 纯递归(不推荐:会爆炸慢)

想法:我想知道f(n),那就去问f(n-1)f(n-2)

def climbStairs(n): if n <= 2: return n return climbStairs(n-1) + climbStairs(n-2)

为什么慢?

因为它会“重复算同一个问题”:

比如算f(5)

f(5)=f(4)+f(3) f(4)=f(3)+f(2) f(3)=f(2)+f(1)

你看:f(3)f(2)被算了很多遍。

复杂度:接近O(2^n),n 稍大就非常慢。


✅ 1.2 递归 + 记忆化(推荐:递归也能很快)

核心:每个f(k)只算一次,算过就记下来,下次直接拿。

def climbStairs(n): memo = {} def dfs(k): if k <= 2: return k if k in memo: return memo[k] memo[k] = dfs(k-1) + dfs(k-2) return memo[k] return dfs(n)

复杂度O(n)
因为1...n每个值只算一次。


2)递推版本(从“小问题”一路推到“大问题”)

递推就是:我先知道最小的答案,然后一步步算到 n。

✅ 2.1 DP 数组版(最直观)

dp[i] 代表到 i 阶的方法数 从 i=3 推到 n

复杂度O(n)时间,O(n)空间。


✅ 2.2 空间优化版(你写的版本:最常用

观察转移方程:

dp[i]只依赖dp[i-1]dp[i-2]
所以没必要保存整个数组,只保留最近两个数就够了。

class Solution: def climbStairs(self, n: int) -> int: if n <= 2: return n a, b = 1, 2 # dp[1], dp[2] for _ in range(3, n + 1): a, b = b, a + b return b

复杂度O(n)时间,O(1)空间。

3)递归 vs 递推:一眼对比

写法思维方向是否重复计算时间复杂度空间复杂度
纯递归自顶向下(n→1)✅会大量重复O(2^n)O(n) 递归栈
递归+记忆化自顶向下(n→1)❌不重复O(n)O(n)
递推 DP 数组自底向上(1→n)❌不重复O(n)O(n)
递推 空间优化自底向上(1→n)❌不重复O(n)O(1)

4)一句话解释

  • 递归:像问路——“到第 n 阶怎么走?那我先问到 n-1 怎么走,再问到 n-2 怎么走。”

  • 递推:像建楼——“先把 1 阶、2 阶的答案写出来,然后一层层推上去。”

http://www.jsqmd.com/news/89169/

相关文章:

  • 基于Java的安全生产考试座位签到智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • 什么叫“结构表示”和“文本表示”不对齐?(Self)
  • 【大模型】-LangChain--RAG文档系统
  • jar(更新中)
  • 基于Java的安全生产视频监控智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • 昇腾CANN从单算子到融合优化实战
  • 探索非线性电液伺服系统的模型自适应反步控制
  • 当AI遇上A股:一个让机器读懂财经新闻的量化框架
  • 21、GNU 开发实用工具:函数、变量与调试技巧
  • 基于Java的安全监管网络人员信息智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • 16、构建与GNU Make的常见问题及算术实现
  • 基于Java的安全生产职业危害智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • 信捷XDM PLC三轴可编程运动控制:强大且灵活的工业利器
  • Numpy基础20问
  • 降AI率就要牺牲文笔?WriterPro第一个不服!实测对比比原文写得还好,这文笔简直绝了
  • 基于Java的安全许可证智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • K8S-蓝绿发布与金丝雀发布
  • 信捷XDM PLC三轴可编程运动控制:打造灵活数控体验
  • YOLOv8+PyQt5西红柿成熟度检测(可以重新训练,yolov8模型,从图像、视频和摄像头三种路径识别检测,包含登陆页面、注册页面和检测页面)
  • 打开软件出现找不到vcomp140.dll文件 无法运行的情况 下载修复解决
  • 基于Java的安全评价师智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • 并发编程的锁有哪些?怎么分类?
  • 2025/12/13
  • 打开软件出现找不到vcruntime140.dll文件 无法运行的情况 下载修复解决
  • 当AI开始“说人话“:微软VibeVoice如何让机器300毫秒内开口
  • 事务操作流程
  • 燕麦矮砧密植:水肥一体化系统的铺设要点
  • 打开软件出现找不到vcruntime140_clr0400.dll文件 无法运行的问题 下载修复解决
  • 字符串(String)是编程语言中一种非常基础且重要的数据类型
  • 紫薯矮砧密植:水肥一体化系统的铺设要点纪实