当前位置: 首页 > news >正文

LeetCode hot 100—爬楼梯

题目

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例

示例 1:

输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶

示例 2:

输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1. 1 阶 + 1 阶 + 1 阶
2. 1 阶 + 2 阶
3. 2 阶 + 1 阶

分析

如果使用递归,时间复杂度是O(2^{n}),呈指数级增长,会超时。

动态规划是对递归方法的优化,避免了重复计算。我们可以使用一个数组来记录到达每一阶楼梯的方法数,然后根据递推关系逐步计算出到达第 n 阶楼梯的方法数。

动态规划法

时间复杂度:O(n)

空间复杂度:O(n)

class Solution {
public:
    int climbStairs(int n) {
        if (n == 1) {
            return 1;
        }
        std::vector<int> dp(n + 1);
        dp[1] = 1;
        dp[2] = 2;
        for (int i = 3; i <= n; ++i) {
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
};

优化空间复杂度的动态规划法

可以发现,在计算到达第 i 阶楼梯的方法数时,只需要用到第 i - 1 阶和第 i - 2 阶的方法数,所以不需要使用一个数组来存储所有的中间结果,只需要使用两个变量来记录这两个值即可。

时间复杂度:O(n)

空间复杂度:O(1)

class Solution {
public:
    int climbStairs(int n) {
        if (n == 1) {
            return 1;
        }
        int first = 1;
        int second = 2;
        for (int i = 3; i <= n; ++i) {
            int third = first + second;
            first = second;
            second = third;
        }
        return second;
    }
};

相关文章:

  • Android 线程池实战指南:高效管理多线程任务
  • leetcode日记(91)二叉树的最大深度
  • E1-106.租车骑绿道(贪心)
  • PDF文件中的颜色是什么原理?
  • 拉取gitlab项目时出现500的错误的权限问题
  • vue3通过render函数实现一个菜单下拉框
  • PIMPL模式
  • 深入理解 GPU 渲染加速与合成层(Composite Layers)
  • 008-生成不重复9位随机数
  • C++ 链表List使用与实现:拷贝交换与高效迭代器细致讲解
  • 分布式数据库OceanBase
  • 面试基础--高并发高可用架构深度实践:降级熔断(Hystrix vs Sentinel)核心原理与源码解析
  • 南昌长空STONE 60A-M 无人机电调深度测评:轻量化设计与工业级安全的融合典范
  • 使用服务器搭建开源建站工具Halo 2.0
  • C++学习——哈希表(一)
  • ASP.NET CORE MVC EF框架
  • JVM常用概念之本地内存跟踪
  • ⭐LeetCode周赛 3468. 可行数组的数目——暴力与数学⭐
  • 深度学习训练Camp:第R5周:天气预测
  • transformer模型介绍——大语言模型 LLMBook 学习(二)
  • 央行最新报告:积极落地5月推出的一揽子金融政策,促进经济供需平衡、物价合理回升
  • 上海杨浦:优秀“博主”购房最高可获200万补贴
  • “20后”比“60后”更容易遭遇极端气候事件
  • 小米回应SU7Ultra排位模式限制车辆动力:暂停推送更新
  • 公募基金改革八大要点:建立浮动管理费收取机制、降低规模排名考核权重
  • 上海:5月8日起5年以上首套个人住房公积金贷款利率下调至2.6%