dp经典问题:爬楼梯

dp经典问题:爬楼梯


爬楼梯

三步问题。有个小孩正在上楼梯,楼梯有n阶台阶,小孩一次可以上1阶、2阶或3阶。实现一种方法,计算小孩有多少种上楼梯的方式。结果可能很大,你需要对结果模1000000007。

Step1: 识别问题

这个问题要求我们计算 小孩上到第n阶台阶有多少种方法

Step2:定义状态

d p i < − 小孩上到第 n 阶台阶的方法数量,定义为第 i 个状态 dpi <- 小孩上到第n阶台阶的方法数量,定义为 第 i 个状态 dpi<−小孩上到第n阶台阶的方法数量,定义为第i个状态

Step3:确定状态转移方程

这里 小孩每次可以上1阶,2阶或3阶 ,也就是说小孩可以从前1阶,2阶或者3阶上到当前台阶

也就是说当前状态由前三个状态决定

d p i = d p i − 1 + d p i − 2 + d p i − 3 dpi=dpi-1+dpi-2+dpi-3 dpi=dpi−1+dpi−2+dpi−3

Step4:确定初始状态和边界

d p 0 = 1 d p 1 = 1 d p 2 = 2 d p 3 = 4 dp0=1\\ dp1=1\\ dp2=2\\ dp3=4 dp0=1dp1=1dp2=2dp3=4

Step5:计算目标状态值

只需要从第四个状态开始自下而上的状态推导即可

代码

cpp 复制代码
class Solution {
public:
    int waysToStep(int n) {
        if (n == 1) return 1;
        if (n == 2) return 2;
        if (n == 3) return 4;

        vector<int> dp(n + 1);
        dp[0] = 1;
        dp[1] = 1;
        dp[2] = 2;
        dp[3] = 4;
        const int mod = 1000000007;

        for (int i = 4; i <= n; ++i) {
            dp[i] = ((dp[i - 1] + dp[i - 2]) % mod + dp[i - 3]) % mod;
        }
        return dp[n];
    }
};
相关推荐
Zhang~Ling15 小时前
C++ 红黑树封装:myset和mymap的底层实现
开发语言·数据结构·c++·算法
ECT-OS-JiuHuaShan15 小时前
什么是对和错?——“有针对性定义域的逻辑值的真伪”:认识论终极追问的公理化裁决
数据库·人工智能·算法·机器学习·数学建模
Merlyn1015 小时前
【栈】155. 最小栈
python·算法
一个不知名程序员www16 小时前
算法学习入门---算法题DAY5
c++·算法
San813_LDD16 小时前
[量化]《虚函数调用时间复杂度完全解析:为什么是 O(1) 以及它的真实代价》
java·数据结构·算法
MartinYeung516 小时前
[论文学习]利用索引梯度优化基于优化的 LLM 越狱攻击:MAGIC 方法的深度分析与实现
人工智能·学习·算法
数据仓库搬砖人16 小时前
特征选择三剑客:前向、后向、全子集,哪种更适合你?
算法
起个破名想半天了16 小时前
算法与数据结构之Floyd算法
数据结构·算法
千寻girling16 小时前
机器学习 | 无监督学习算法(了解) | 尚硅谷学习
学习·算法·机器学习
小七在进步16 小时前
数据结构:线性表之顺序表
c语言·数据结构·算法