【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;
    }
};
相关推荐
星轨初途4 分钟前
C++的输入输出(上)(算法竞赛类)
开发语言·c++·经验分享·笔记·算法
n***F8756 分钟前
SpringMVC 请求参数接收
前端·javascript·算法
Liangwei Lin16 分钟前
洛谷 P1025 [NOIP 2001 提高组] 数的划分
算法
极地星光16 分钟前
Qt/C++ 单例模式深度解析:饿汉式与懒汉式实战指南
c++·qt·单例模式
yuuki23323333 分钟前
【C++】类和对象(上)
c++·后端·算法
再睡一夏就好39 分钟前
string.h头文件中strcpy、memset等常见函数的使用介绍与模拟实现
c语言·c++·笔记·string·内存函数·strcpy
dangdang___go40 分钟前
动态内存管理||malloc和free.realloc和calloc
c语言·开发语言·算法·动态内存管理
稚辉君.MCA_P8_Java40 分钟前
Gemini永久会员 快速排序(Quick Sort) 基于分治思想的高效排序算法
java·linux·数据结构·spring·排序算法
数字化脑洞实验室1 小时前
智能决策与决策优化:从算法到产业的演进逻辑
算法
cpp_25011 小时前
P5412 [YNOI2019] 排队
数据结构·c++·算法·题解·洛谷