【Hot 100】70. 爬楼梯

目录

  • 🙋‍♂️ 作者:海码007
  • 📜 专栏:算法专栏
  • 💥 标题:【Hot 100】70. 爬楼梯
  • ❣️ 寄语:书到用时方恨少,事非经过不知难!

引言

爬楼梯

  • 🎈 题目链接:
  • 🎈 做题状态:

我的解题

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n == 1) return 1;
        // 经典的dp题目,当前状态由前面的状态决定
        vector<int> dp(n);  // dp[i] 表示爬第i+1个台阶的方法数
        dp[0] = 1;
        dp[1] = 2;

        for (int i = 2; i < n; ++i)
        {
            dp[i] = dp[i-1] + dp[i - 2];    // 当前状态有前两种状态决定
        }

        return dp[n-1];
    }
};

代码优化

仔细观看上面的代码可以发现,dp数组在计算的过程中只依赖前面两个状态,所以可以将存储空间进行压缩。只需要两个额外变量来记录就行。

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n == 1) return 1;
        // 经典的dp题目,当前状态由前面的状态决定
        int pre = 1;
        int mid = 2;
        int next = mid;

        for (int i = 2; i < n; ++i)
        {
            next = pre + mid;
            pre = mid;
            mid = next;
        }

        return next;
    }
};
相关推荐
cpp_250117 小时前
P8395 [CCC 2022 S1] Good Fours and Good Fives
数据结构·c++·算法·动态规划·图论·题解·洛谷
AI科技星17 小时前
基于空间光速螺旋第一性原理的电荷本源定义与电场时空协变方程的完整推导、严格证明及全尺度数值验证
c语言·开发语言·算法·机器学习·数据挖掘
云泽80817 小时前
蓝桥杯算法精讲:深剖分治算法及其经典应用
算法·职场和发展·蓝桥杯
志摩凛17 小时前
范畴论——前端与计算机领域的“抽象工具箱”:该用则用,该弃则弃
算法·架构
2401_8579182917 小时前
C++与自动驾驶系统
开发语言·c++·算法
乐分启航17 小时前
【无标题】
深度学习·算法·目标检测·transformer·迁移学习
liu****18 小时前
linux上git推送内容到gitee上
c++·git·gitee·版本控制
GfovikS0610018 小时前
C++中的函数式编程
开发语言·c++·算法
2401_8579182918 小时前
C++中的构建器模式
开发语言·c++·算法
liu****18 小时前
6.多人协作(同一分支下(不常用))(一)
c++·gitee·版本控制