代码随想录 70.爬楼梯

思路:爬到第一层有1种方法,爬到第二层有2种方法。那么第一层楼梯再跨两步就到第三层,第二层楼梯再跨一步就到第三层。所以到第三层楼梯的状态可以由第二层楼梯和第一层楼梯的状态推导出来,所以可以动态规划。

动规五部曲:

本题需要一个一维数组来记录不同楼层的状态。

1.确定dp数组及其下标的含义:

dpi:爬到第i层楼梯,有dpi种方法。

2.确定递推公式:

如何可以推出dpi呢?从dpi的定义来看,dpi可以有两个方向推出来。

(1)首先是dpi - 1,上i - 1层楼梯,有dpi - 1种方法,那么下一步上1个台阶就到dpi了。

(2)还有dpi - 2,上i - 2层楼梯,有dpi - 2种方法,那么下一步上2个台阶就到dpi了。

因此dpi就是dpi - 1和dpi - 2的和。

dpi = dpi - 1 + dpi - 2

在推导dpi的时候,一定要时刻想着dpi的定义,否则容易跑偏。这体现出确定dp数组及其下标含义的重要性。

3.dp数组如何初始化:

dpi的含义是,爬到第i层楼梯,有dpi种方法。

那么i为0时,dpi应该为多少?在本题中,i为0时,dp0 = 0 或 dp0 = 1有争议。这是因为第0层台阶,既可以解释为爬到第0层也是一种方法,所以dp0 = 1;也可以解释为dp0时楼层是0,直接站在楼顶上了没有移动,所以dp0 = 1。在本题中,n是一个正整数,所以题目中没有n为0的情况。所以本题不需要讨论dp0的初始化。而本题中,dp1 = 1,dp2 = 2是没有争议的。所以本题不考虑dp0如何初始化,只初始化dp1 = 1,dp2 = 2,然后从i = 3开始递推,这样才符合dpi的定义。

4.确定遍历顺序:

从递推公式 dpi = dpi - 1 + dpi - 2可以得出,遍历顺序是从前向后的。

5.举例推导dp数组:

当n为5时,dp数组如下所示。

附代码:

java 复制代码
class Solution {
    public int climbStairs(int n) {
        if(n <= 2) return n;
        int[] dp = new int[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];
    }
}
java 复制代码
//用变量记录代替数组
class Solution {
    public int climbStairs(int n) {
        if(n <= 2) return n;
        int a = 1,b = 2,sum = 0;
        for(int i = 3;i <= n;i++){
            sum = a + b;
            a = b;
            b = sum;
        }
        return b;
    }
}
相关推荐
白鲸开源7 小时前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源7 小时前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github
用户2986985301411 小时前
Java 实现 Word 文档文本查找与高亮标注
java·后端
宇宙之一粟12 小时前
乐企版式文件生成平台
java·后端·python
plainGeekDev12 小时前
MVC 写法 → MVVM
android·java·kotlin
SL_staff13 小时前
3周搭完MES系统:JVS低代码+JVS-IoT物联网的实战记录
java·前端·低代码
MacroZheng13 小时前
斩获20w star!Claude Code最强插件,AI编程必备!
java·人工智能·后端
唐青枫14 小时前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
小bo波1 天前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking1 天前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试