【Golang】LeetCode 70. 爬楼梯

70. 爬楼梯

题目描述

思路

下班之后又想偷懒了,但最近学习了"日行 20 英里"的原则,写几道题并整理一下思路吧。

爬楼梯是最经典的一道一维动态规划问题。由于这道题已经刷过太多次了,基本上每次再遇到都是速敲一遍秒过,发现我好像已经很久没有思考过这道题是如何运用动态规划了。本着熟络熟络算法,写一道题就整理一道题的原则,现在对这部分的思考它来了。

解这道题目我一般会加入一道特判,首先判断n == 0n == 1n == 2三种情况。针对n == 0的情况,显然不存在任何爬楼梯的方案,答案就是0;针对n == 1的情况,题目中已经明确说我们每次可以爬一格楼梯或两格楼梯,显然此时只有一级台阶,我们只能爬一格,所以此时答案就是1;针对n == 2的情况,我们可以爬楼梯的方案有两种,要么在第零级一次爬两格,要么分两次,每次爬一格,因此答案就是2

分析到这里,我们不难看出,实际上这道题目最后要求的,就是我们有无穷多个12,从0开始我们每次可以加1或加2,有多少种方案最后可以得到和为n。解决的方法其实很简单,我们可以使用一个名为dp的数组来记录每一个i∈(0,n]i \in (0, n]i∈(0,n]的数的加和方案数。初始时我们已经知道dp[0] = 0dp[1] = 1以及dp[2] = 2,因此从i == 3开始,我们有状态转移方程dp[i] = dp[i - 1] + dp[i - 2],比如从第3级开始,我们的方案要么是从第1级爬两个台阶,要么是从第2级爬一格台阶。dp统计的是方案数,而不是真实的爬台阶级数,因此这里是对方案数进行汇总。

最后,返回dp[n]就是最后的答案。

Golang 题解

go 复制代码
func climbStairs(n int) int {
    if n == 0 {
        return 0
    } else if n == 1 {
        return 1
    } else if n == 2 {
        return 2
    }
    dp := make([]int, n + 1)
    dp[0], dp[1], dp[2] = 0, 1, 2
    for i := 3; i <= n; i ++ {
        dp[i] = dp[i - 1] + dp[i - 2]
    }
    return dp[n]
}
相关推荐
無限進步D21 小时前
蓝桥杯赛前刷题
c++·算法·蓝桥杯·竞赛
CoderCodingNo21 小时前
【GESP】C++二级真题 luogu-B4497, [GESP202603 二级] 数数
开发语言·c++·算法
磊 子21 小时前
八大排序之冒泡排序+选择排序
数据结构·算法·排序算法
_深海凉_21 小时前
LeetCode热题100-买卖股票的最佳时机
leetcode
We་ct21 小时前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
潇洒畅想21 小时前
1.1 从∑到∫:用循环理解求和与累积
java·数据结构·python·算法
郝学胜-神的一滴1 天前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
ZC跨境爬虫1 天前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
计算机安禾1 天前
【数据结构与算法】第41篇:图论(五):拓扑排序与关键路径
c语言·数据结构·c++·算法·图论·visual studio
Q741_1471 天前
每日一题 力扣 1320. 二指输入的的最小距离 动态规划 C++ 题解
c++·算法·leetcode·动态规划