每日一练:爬楼梯

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);
    }
};
相关推荐
wuweijianlove11 分钟前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊15 分钟前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
徐某人..1 小时前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
无敌秋1 小时前
# C++ 简单工厂模式实战指南
c++·简单工厂模式
code_pgf2 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
cany10002 小时前
C++ -- 模板的声明和定义
开发语言·c++
澈2072 小时前
深耕进阶 Day1:C 与 C++ 核心差异 + C++ 入门基石
c语言·开发语言·c++
嘻嘻哈哈樱桃2 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
脱氧核糖核酸__2 小时前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表