力扣 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;
    }
};
相关推荐
小江的记录本15 小时前
【JVM虚拟机】垃圾回收GC:垃圾判定算法:引用计数法、可达性分析算法(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·spring·面试
Hello.Reader15 小时前
算法基础(十四)—— 随机化快速排序为什么平均表现很好
算法
吴可可12315 小时前
Teigha中OdGe几何库详解及C#使用
算法
爱喝水的鱼丶15 小时前
SAP-ABAP:变量、常量、结构与内表声明(10篇博客合集) 第六篇:ABAP 7.40+新特性:声明语法的简化写法与兼容注意事项
运维·服务器·开发语言·学习·算法·sap·abap
国科安芯15 小时前
AS32S601商业航天级抗辐照MCU芯片:架构设计与技术特性研究
单片机·嵌入式硬件·算法·安全·架构·risc-v
RuiZN16 小时前
UE5 UObject类详解
c++·ue5
ZhangShao060716 小时前
题解:AT_abc459_e
c++
菜菜的顾清寒16 小时前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论
圣保罗的大教堂16 小时前
leetcode 2657. 找到两个数组的前缀公共数组 中等
leetcode
名字不好奇16 小时前
大模型的思考模式:它真的在“想“吗?
人工智能·算法