当前位置: 首页 > article >正文

LeetCode-面试题08.01 三步问题 C/C++实现 超详细思路及过程[E]

在这里插入图片描述

🎈归属专栏:深夜咖啡配算法
🚗个人主页:Jammingpro
🐟记录一句:摆了一个周末了,不能摆了,努力起来!!

文章目录

  • LeetCode-面试题08.01 三步问题
    • 🚗题目
      • 🚆题目描述
      • 🚆题目示例
      • 🚆提示
    • 🚗题解
      • 🚆动态规划法

LeetCode-面试题08.01 三步问题

标签:动态规划、记忆化搜索、数学


🚗题目

🚆题目描述

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

🚆题目示例

示例 1:

输入:n = 3
输出:4
说明: 有四种走法

示例 2:

输入:n = 5
输出:13

🚆提示

n范围在[1, 1000000]之间


🚗题解

🚆动态规划法

这一题与70.爬楼梯问题类似【传送门】,当我要爬到第n个台阶时,我可以是从n-1号台阶爬1个台阶后到达,可以是从n-2号台阶爬2个台阶后到达,还可以是从n-3号台阶爬3个台阶后到达。因而,可以得到递推公式 T n T_{n} Tn= T n − 3 T_{n-3} Tn3+ T n − 2 T_{n-2} Tn2+ T n − 3 T_{n-3} Tn3。从题意可知, T 0 T_{0} T0=1, T 1 T_{1} T1=1, T 2 T_{2} T2=2。得到初始化的几个数值及递推公式,我们就可以实现代码了👇

class Solution {
public:
    int waysToStep(int n) {
        const int MOD = 1000000007;
        if(n == 0 || n == 1) return 1;
        if(n == 2) return 2;
        int t0 = 1, t1 = 1, t2 = 2;
        for(int i = 3; i <= n; i++)
        {
            int tmp = ((t0 + t1) % MOD + t2) % MOD;
            t0 = t1;
            t1 = t2;
            t2 = tmp;
        }
        return t2;
    }
};

文章结语:这道题是一道简单题,算是动态规划入门类题目了!!
🎈欢迎进入深夜咖啡配算法专栏,查看更多文章。
如果上述内容有任何问题,欢迎在下方留言区指正b( ̄▽ ̄)d


http://www.kler.cn/a/148557.html

相关文章:

  • 论文解析:边缘计算网络中资源共享的分布式协议(2区)
  • 【QT】QSS
  • 如何用WordPress和Shopify提升SEO表现?
  • STM32嵌入式闹钟系统设计与实现
  • LeetCode【0036】有效的数独
  • Linux设置socks代理
  • 【云栖 2023】姜伟华:Hologres Serverless 之路——揭秘弹性计算组
  • MySQL学习day03
  • 9.增删改操作
  • [autojs]ui线程中更新控件的值的问题
  • 中小型公司如何搭建运维平台,rancher、kubersphere、rainbond
  • 漏洞环境靶场搭建(内含DVWA SQLi-LABS upload-labs等)
  • mybatis <include refid=“xxx“></include>
  • 【每日一题】1457. 二叉树中的伪回文路径-2023.11.25
  • 142. 环形链表 II --力扣 --JAVA
  • linux 提权
  • XML Schema中的simpleContent 元素
  • os和path模块
  • NI自动化测试系统用电必备攻略,电源规划大揭秘
  • 成为AI产品经理——TPR、FPR、ROC、AUC
  • vue3-09
  • 5.28每日一题(函数在区间有/无界的判断:相关定理(充分条件))
  • Kanna库代码示例
  • 股票技术从初级到高级,从实盘进阶到摩尔缠论
  • Unity优化——脚本优化策略3
  • mac Terminal config proxy 【mac 终端配置代理】