每日一练:爬楼梯

70. 爬楼梯 - 力扣(LeetCode)

题目要求:

解法-1 动态规划 O(N)

这是一道简单的动态规划题,要得到达到第 i 个阶梯的方法总数,就需要得到到达它的上一步 i-1和 i-2 的方法总数,即:dp[i] = dp[i-1]+dp[i-2]。

使用虚拟位让代码更简洁:

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        vector<int> dp(n+2);
        dp[0] = 0; // 虚拟位初始化
        dp[1] = 1; // 虚拟位初始化

        for(int i = 2;i < n+2;i++)
        {
            dp[i] = dp[i-1]+dp[i-2];
        }
        return dp[n+1];
    }
};

优化-使用滑动数组减少内存消耗:

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        int a = 0;
        int b = 1;
        int c;
        for(int i = 0;i < n;i++)
        {
            c = a + b;
            a = b;b = c;
        }
        return c;
    }
};

解法-2 递归 O(N) 会超时

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if(n <= 2)
            return n;
        return climbStairs(n-1)+climbStairs(n-2);
    }
};
相关推荐
ghie90905 分钟前
基于libsvm的支持向量机在MATLAB中的实现
算法·支持向量机·matlab
Samsong2 小时前
《C++ Primer Plus》读书笔记 第二章 开始学习C++
c++·后端
Rubisco..2 小时前
牛客周赛 Round 111
数据结构·c++·算法
兮山与2 小时前
算法8.0
算法
高山上有一只小老虎2 小时前
杨辉三角的变形
java·算法
Swift社区2 小时前
LeetCode 395 - 至少有 K 个重复字符的最长子串
算法·leetcode·职场和发展
Espresso Macchiato2 小时前
Leetcode 3710. Maximum Partition Factor
leetcode·职场和发展·广度优先遍历·二分法·leetcode hard·leetcode 3710·leetcode双周赛167
hz_zhangrl2 小时前
CCF-GESP 等级考试 2025年9月认证C++四级真题解析
开发语言·c++·算法·程序设计·gesp·c++四级·gesp2025年9月
火山灿火山2 小时前
详解AVL树旋转操作实现
数据结构·c++
少许极端3 小时前
算法奇妙屋(六)-哈希表
java·数据结构·算法·哈希算法·散列表·排序