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的时候有多少种方法走上台阶。

相关推荐
wasp5201 分钟前
Hudi 元数据管理分析
java·大数据·linux·hudi·数据湖·数据湖仓
其言2 分钟前
使用 docker-compose 启动的 nginx 容器证书过期
java
凋零蓝玫瑰3 分钟前
几何:数学世界的空间密码
人工智能·算法·机器学习
kk”3 分钟前
C++ AVL树
开发语言·数据结构·c++
uup3 分钟前
RabbitMQ 在 Java 应用中内存溢出问题
java·rabbitmq
urkay-5 分钟前
Android 全局修改设备的语言设置
android·xml·java·kotlin·iphone
编程修仙5 分钟前
第四篇 封装SqlSessionFactory
java·数据库·mybatis
程序员西西7 分钟前
SpringBoot 隐式参数注入:告别重复代码,让 Controller 更优雅
java·后端
Tao____10 分钟前
国产开源物联网平台
java·物联网·mqtt·iot·设备对接