从零开始的LeetCode刷题日记:70. 爬楼梯

一.相关链接

题目链接: 70. 爬楼梯

二.心得体会

这道题还是动规五部曲。

1.首先是dp数组及其下标的含义,dp记录了每层楼梯对应的爬的方法,每个下标存储每个对应楼层。

2.然后是递归公式,其实每一层楼都是可以从下面一层和下面两层爬上来,所以其实就是dp[i] = dp[i - 1] + dp[i - 2] 。

3.dp数组初始化就把第一层初始化为1,第二层为2。

4.遍历顺序是从前往后。

5.具体推导出来没问题,就是斐波那契!

三.代码
cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        int ans[46] = {0};
        ans[2] = 2;
        ans[1] = 1;
        for(int i=3;i<n+1;i++) {
            ans[i] = ans[i-1] + ans[i-2];
        }
        return ans[n];
    }
};
相关推荐
lihao lihao4 分钟前
进程地址空间
数据结构·c++·算法
Byte不洛5 分钟前
LeetCode双指针经典题
c++·算法·leetcode·双指针
汀、人工智能6 分钟前
[特殊字符] 第16课:最小覆盖子串
数据结构·算法·数据库架构·图论·bfs·最小覆盖子串
米粒110 分钟前
力扣算法刷题 Day 34
算法·leetcode·职场和发展
田梓燊24 分钟前
leetcode 189
算法·leetcode·职场和发展
仍然探索未知中25 分钟前
【Linux内核源码分析】内核数据结构
linux·数据结构
wuweijianlove38 分钟前
算法复杂度的理论边界与实验验证研究的技术3
算法
rm6fEx0Z744 分钟前
AUC 与 GAUC:从全局排序到用户内排序的理解
人工智能·算法·机器学习
minji...1 小时前
Linux 多线程(四)线程等待,线程分离,线程管理,C++多线程,pthread库
linux·运维·开发语言·网络·c++·算法
H_BB1 小时前
DFS实现回溯算法
数据结构·c++·算法·深度优先