力扣70. 爬楼梯

动态规划

  • 思路:
    • 使用递归比较容易理解, f(n) = f(n - 1) + f(n - 2);
      • 到剩余1级台阶有 f(n - 1),到剩余2级台阶有 f(n-2);
      • 边界情况是
        • n = 0, f(0) = 1
        • n = 1, f(1) = 1
        • n = 2, f(2) = 2
      • 递归代码实现:
cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n == 0) {
            return 1;
        }
        if (n == 1) {
            return 1;
        }

        if (n == 2) {
            return 2;
        }

        return climbStairs(n - 1) + climbStairs(n - 2);
    }
};
  • 很遗憾的事 n = 44 时,反馈超时了;所以,需要将递归变换一下;
  • 使用两个变量来缓存前两种情形的结果,根据转移方程 f(n) = f(n - 1) + f(n - 2),迭代 n 次即可;
cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        int p = 0;
        int q = 0;
        int result = 1;
        
        for (int step = 1; step <= n; ++step) {
            p = q;
            q = result;
            result = p + q;
        }

        return result;
    }
};
相关推荐
学学学无无止境2 分钟前
力扣-路径总和
leetcode
flashlight_hi13 分钟前
LeetCode 分类刷题:1669. 合并两个链表
javascript·leetcode·链表
智者知已应修善业44 分钟前
【给定英文字符串统计最多小写最前输出】2023-2-27
c语言·开发语言·c++·经验分享·笔记·算法
饮品爱好者44 分钟前
[C#] NO.4 我的第一个项目
vscode·职场和发展·c#·github
RWKV元始智能1 小时前
体验RWKV-7训练全过程,只需400行代码训练3分钟
人工智能·算法·机器学习
点云SLAM1 小时前
四元数 (Quaternion)微分-四元数导数的矩阵表示推导(8)
线性代数·算法·计算机视觉·矩阵·机器人·slam·四元数
kyle~2 小时前
算法---贪心算法(Greedy Algorithm)
算法·贪心算法
fashion 道格2 小时前
C 语言数组拼接:从基础实现到细节优化
算法
头发还没掉光光2 小时前
Linux多线程之自旋锁与读写锁
linux·运维·算法
fashion 道格2 小时前
C 语言希尔排序:原理、实现与性能深度解析
数据结构·算法·排序算法