HOT100力扣(40) 动态规划-爬楼梯

这道题本质就是斐波那契数列,是动态规划的入门第一题。

核心思路(一句话讲透):

要爬到第 n 阶台阶,最后一步只有两种可能:

  1. 从第 n-1 阶爬 1 阶上来
  2. 从第 n-2 阶爬 2 阶上来 所以爬到第 n 阶的总方法数 = 爬到 n-1 阶的方法数 + 爬到 n-2 阶的方法数

. 完整解题步骤

  1. 定义状态 :用f(x)表示爬到第 x 阶台阶的总方法数
  2. 推导转移方程f(x) = f(x-1) + f(x-2)
  3. 确定边界条件
    • f(0) = 1:站在第 0 阶(起点),只有 1 种方法(不用爬)
    • f(1) = 1:爬到第 1 阶,只有 1 种方法(爬 1 阶)
  4. 空间优化(滚动数组) : 因为f(x)只和f(x-1)f(x-2)有关,不需要保存整个数组,只用 3 个变量滚动更新即可,空间复杂度从 O (n) 降到 O (1)。

不管名字怎么变,永远遵守:

新值 = 前一个值 + 前前一个值

这里:

  • r 永远是最新算出来的结果(对应 f (i))
  • q 是上一轮的结果(对应 f (i-1))
  • p 是上上轮的结果(对应 f (i-2))
cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {

        //r表示最后的可能 r等于前n-1和n-2的可能数的和
        /*p:代表 f(i-2)(上上个台阶的方法数)
q:代表 f(i-1)(上一个台阶的方法数)
r:代表 f(i)(当前台阶的方法数)*/
        //r=1 表示在从0到1台阶的方法只有一个
        int p = 0,q = 0,r = 1;
        for(int i = 1;i<=n;i++){//从台阶1开始走
            p = q;//
            q = r;//
            r = p +q;
        }
        return r;
        
    }
};
相关推荐
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆2 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben0442 天前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..2 天前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅10052 天前
【leetcode】88.合并两个有序数组js
算法