爬楼梯(动态规划)

目录

爬楼梯

算法思想

基本情况

动态规划递推关系

核心思想

时间复杂度与空间复杂度

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];
};
相关推荐
m0_629494732 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户2 小时前
用队列实现栈
数据结构·算法
做人求其滴2 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7773 小时前
记一组无人机IMU传感器数据
算法
计算机安禾3 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
Shan12053 小时前
什么是换根DP及第一步操作说明
动态规划
小O的算法实验室3 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-3 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~3 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界3 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构