Leetcode 03 java

爬楼梯算法

现在只看明白动态规划,也没有很难哟!!

题目
java 复制代码
70. 爬楼梯

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

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

 
java题解
java 复制代码
class Solution {
    public int climbStairs(int n) {
        int p = 0, q = 0, r = 1;
        for (int i = 1; i <= n; ++i) {
            p = q; 
            q = r; 
            r = p + q;
        }
        return r;
    }
}

这个爬楼梯算法实际上是一个经典的动态规划问题,也可以看作是斐波那契数列的变种。让我来详细解释一下:

问题理解

假设你正在爬楼梯,需要n阶才能到达楼顶。每次你可以爬 1 或 2 个台阶。问有多少种不同的方法可以爬到楼顶?

例如:

  • n=2时,有两种方法:1+1 或直接 2 步
  • n=3时,有三种方法:1+1+1、1+2、2+1
  • n=4时,有五种方法:1+1+1+1、1+1+2、1+2+1、2+1+1、2+2

动态规划思路

动态规划的核心是将大问题分解为小问题,并存储小问题的解避免重复计算。

对于爬楼梯问题,关键观察点是:

  • 到达第i阶楼梯的方法数 = 到达第i-1阶的方法数(再爬 1 步) + 到达第i-2阶的方法数(再爬 2 步)
  • 即状态转移方程:dp[i] = dp[i-1] + dp[i-2]

代码解释

你提供的代码正是基于这个思路实现的,只不过使用了滚动数组优化空间复杂度:

java

java 复制代码
public int climbStairs(int n) {
    int p = 0, q = 0, r = 1;
    for (int i = 1; i <= n; ++i) {
        p = q;     // p 记录 dp[i-2] 的值
        q = r;     // q 记录 dp[i-1] 的值
        r = p + q; // r 计算当前 dp[i] = dp[i-1] + dp[i-2]
    }
    return r;
}

执行过程示例

n=3为例:

  1. 初始状态:p=0, q=0, r=1
  2. 循环开始:
    • i=1: p=0, q=1, r=p+q=1 → 到达第 1 阶有 1 种方法
    • i=2: p=1, q=1, r=p+q=2 → 到达第 2 阶有 2 种方法
    • i=3: p=1, q=2, r=p+q=3 → 到达第 3 阶有 3 种方法
  3. 返回结果:r=3

复杂度分析

  • 时间复杂度:O (n),只需遍历一次
  • 空间复杂度:O (1),只使用了三个变量

这种优化方法避免了创建长度为n的数组,在空间效率上更高。本质上,这个问题和斐波那契数列的计算是一样的,只是起始条件略有不同(斐波那契通常从 0 和 1 开始,而爬楼梯这里从 1 和 1 开始)。

相关推荐
浮生带你学Java2 分钟前
2025Java面试题及答案整理( 2025年 7 月最新版,持续更新)
java·开发语言·数据库·面试·职场和发展
拾光拾趣录4 分钟前
链表合并:双指针与递归
前端·javascript·算法
好易学·数据结构9 分钟前
可视化图解算法56:岛屿数量
数据结构·算法·leetcode·力扣·回溯·牛客网
香蕉可乐荷包蛋1 小时前
AI算法之图像识别与分类
人工智能·学习·算法
chuxinweihui2 小时前
stack,queue,priority_queue的模拟实现及常用接口
算法
tomato092 小时前
河南萌新联赛2025第(一)场:河南工业大学(补题)
c++·算法
墨染点香2 小时前
LeetCode Hot100【5. 最长回文子串】
算法·leetcode·职场和发展
甄卷3 小时前
李沐动手学深度学习Pytorch-v2笔记【08线性回归+基础优化算法】2
pytorch·深度学习·算法
Ashlee_code3 小时前
美联储降息趋缓叠加能源需求下调,泰国证券交易所新一代交易系统架构方案——高合规、强韧性、本地化的跨境金融基础设施解决方案
java·算法·金融·架构·系统架构·区块链·需求分析
屁股割了还要学3 小时前
【C语言进阶】内存函数
c语言·开发语言·学习·算法·青少年编程