LeetCode70:爬楼梯

复制代码
class Solution {
public:
    int climbStairs(int n) {
        if(n == 1)  return 1;
        if(n == 2)  return 2;
        vector<int> dp(n + 1, 0);
        dp[1] = 1;
        dp[2] = 2;
        for(int i = 3; i < n +1; i++)
        {
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
};

这个题目也就是最简单的动态规划,题目很难理解,实际上当你递推几个之后就好办了很多。

n = 1 有1种方法

n = 2 有2种方法

n = 3 有3种方法

n = 4 有5种方法

n = 5 有8种方法

也就是斐波那契数列,区别就在n = 0时,这个题目没有n = 0,也就是没有0阶楼梯这一说法

看着程序员卡尔的动态规划五部曲也就是五步走,然后确定dp状态转移方程,最后算出来n的时候有多少种方法走上台阶。

相关推荐
Liangwei Lin3 分钟前
洛谷 P1464 Function
算法
二十雨辰5 分钟前
[天机学堂]-01环境搭建
java·spring cloud
代码游侠7 分钟前
数据结构——单向链表
linux·开发语言·数据结构·学习·算法·链表
CoovallyAIHub8 分钟前
AI 项目如何避免“烂尾”?怎么选择才能让AI项目长期奔跑?
人工智能·算法·计算机视觉
h***593312 分钟前
JAVA进阶 Thread学习06 synchronized关键字
java·开发语言·学习
j***485412 分钟前
【JSqlParser】Java使用JSqlParser解析SQL语句总结
java·开发语言·sql
如意.75913 分钟前
【C++】——异常
java·开发语言
liberty88816 分钟前
dppt如何找到弹框
java·服务器·前端
s***385619 分钟前
Spring 中的 @ExceptionHandler 注解详解与应用
java·后端·spring
qq_4308558819 分钟前
线性代数第一章第一课: 二阶三阶行列式
线性代数·算法·矩阵