力扣 70. 爬楼梯

题目来源:https://leetcode.cn/problems/climbing-stairs/description/

C++题解(来源代码随想录): 本质上是一道斐波那契数题。

动规五部曲:定义一个一维数组来记录不同楼层的状态

  1. 确定dp数组以及下标的含义。dpi: 爬到第i层楼梯,有dpi种方法
  2. 确定递推公式。如何可以推出dpi呢?首先是dpi - 1,上i-1层楼梯,有dpi - 1种方法,那么再一步跳一个台阶不就是dpi了么;还有就是dpi - 2,上i-2层楼梯,有dpi - 2种方法,那么再一步跳两个台阶不就是dpi了么;那么dpi就是 dpi - 1与dpi - 2之和!所以dpi = dpi - 1 + dpi - 2
  3. dp数组如何初始化。dp1 = 1,dp2 = 2
  4. 确定遍历顺序。从递推公式dpi = dpi - 1 + dpi - 2;中可以看出,遍历顺序一定是从前向后遍历的
  5. 举例推导dp数组。
cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n <= 1) return n; // 因为下面直接对dp[2]操作了,防止空指针
        vector<int> dp(n + 1);
        dp[1] = 1;
        dp[2] = 2;
        for (int i = 3; i <= n; i++) { // 注意i是从3开始的
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
};
cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if(n <= 2) return n;
        vector<int> dp(2);
        dp[0] = 1; dp[1] = 2;
        int sum = 0;
        for(int i = 2; i < n; i++) {
            sum = dp[0] + dp[1];
            dp[0] = dp[1];
            dp[1] = sum;
        }
        return sum;
    }
};
相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎1 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾1 小时前
多头注意力机制
人工智能·深度学习·算法
H178535090961 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
hujinyuan201601 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
玖玥拾1 小时前
C/C++ 基础笔记(十三)继承
c语言·c++·继承
bIo7lyA8v2 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程2 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
ao-weilai3 小时前
C++:哈希表
c++·哈希算法·散列表
汉克老师3 小时前
GESP7级C++考试语法知识(二、指数函数(1、pow() 函数)
c++·指数函数·pow·gesp7级·精度误差
退休倒计时3 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript