算法---动态规划练习-1(三步问题)

三步问题

  • [1. 题目解析](#1. 题目解析)
  • [2. 讲解算法原理](#2. 讲解算法原理)
  • [3. 编写代码](#3. 编写代码)

1. 题目解析

题目地址三步问题

2. 讲解算法原理


1. 定义一个常量MOD为10^9+7,用于取模运算。

2. 创建一个长度为n+3的数组dp,用于存储计算过程中的中间结果。数组的下标表示台阶的级数,数组元素存储对应级数时的上楼方式数。

3. 初始化数组的前三个元素dp1、dp2和dp3分别为1、2、4,这是台阶数为1、2、3时的上楼方式数。

4. 如果n小于等于3,直接返回dpn,即台阶数为n时的上楼方式数。

5. 从i=4开始,通过循环填充数组dp的剩余元素。对于每个i,计算台阶数为i时的上楼方式数。根据题意,可以从前一级台阶跨一步上来、从前两级台阶跨两步上来,或者从前三级台阶跨三步上来。因此,dpi = (dpi-3 + dpi-2 + dpi-1) % MOD,其中% MOD是为了防止整数溢出。

6. 循环结束后,数组dp中的所有台阶数对应的上楼方式数都已计算得到

7. 返回dpn,即n级台阶的上楼方式数。


3. 编写代码

cpp 复制代码
class Solution {
public:

    int waysToStep(int n) {
        
        const int MOD=1e9+7;
        vector<long long> dp(n+3);
        dp[1]=1,dp[2]=2,dp[3]=4;

        if(n<=3) return dp[n];
        for(int i=4;i<=n;i++)
        {
            dp[i]=(dp[i-3]+dp[i-2]+dp[i-1])%MOD;
        }
        return dp[n];
    }
};
相关推荐
vibecoding日记6 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr21388 小时前
Verilog参数化游程编码RLE模块
算法
望易8 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络12 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc