爬楼梯(动态规划)

目录

爬楼梯

算法思想

基本情况

动态规划递推关系

核心思想

时间复杂度与空间复杂度

code


力扣第70题

爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 12 个台阶。你有多少种不同的方法可以爬到楼顶呢?

算法思想

基本情况

javascript 复制代码
dp[0] = 1;  // 0个台阶 - 1种方法(什么都不做)
dp[1] = 1;  // 1个台阶 - 1种方法(只能爬1步)

动态规划递推关系

javascript 复制代码
for(let i = 2; i <= n; i++) {
    dp[i] = dp[i - 1] + dp[i - 2];
}

核心思想

  • 要到达第 i 级台阶,可以:

从第 i-1 级爬 1 步 上来(有 dp[i-1] 种方法)【爬上 n−1 阶楼梯的方法数量。因为再爬1阶就能到第n阶

从第 i-2 级爬 2 步 上来(有 dp[i-2] 种方法)【爬上 n−2 阶楼梯的方法数量,因为再爬2阶就能到第n阶

  • 因此:dp[i] = dp[i-1] + dp[i-2]

可以换种角度理解

只考虑最后一步,假设有4个台阶,最后一步有两种走法(剩下一个台阶的可能性组合和剩下两个台阶可能性组合)。两种走法的所有可能性都想家就是所有的可能性。
举例:

  • 1+1+1+1 剩下一个台阶
  • 1+2+1 剩下一个台阶
  • 2+1+1 剩下一个台阶
  • 1+1+2 剩下两个台阶
  • 2+2 剩下两个台阶

根据列出的规律可以发现剩下一个台阶的走法是(4-1)个台阶走法的总和;剩下两个台阶的走法(4-2)个台阶的走法的总和。因此可以得出结论假设有n个台阶那总的走法总数等于(n-1)个台阶走法数和(n-2)个台阶走法数的相加

即 dp[n]=dp[n−1]+dp[n−2]

时间复杂度与空间复杂度

  • 时间复杂度:O(n) - 只需遍历一次

  • 空间复杂度:O(n) - 需要长度为 n+1 的数组

code

javascript 复制代码
/**
 * @param {number} n
 * @return {number}
 */
var climbStairs = function(n) {
    const dp = [];
    dp[0] = 1;
    dp[1] = 1;
    for(let i = 2; i <= n; i++) {
        dp[i] = dp[i - 1] + dp[i - 2];
    }
    return dp[n];
};
相关推荐
旖-旎1 天前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰1 天前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx1 天前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer1 天前
【无标题】
开发语言·c++·算法
AGV算法笔记1 天前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家1 天前
数据链路层基础
网络·学习·算法
Advancer-1 天前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤1 天前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre1 天前
78 子集
算法·leetcode·深度优先·回溯
天威?*1 天前
bitset的数据结构用法
算法·动态规划