• 【算法挨揍日记】day17——1137. 第 N 个泰波那契数、面试题 08.01. 三步问题


     1137. 第 N 个泰波那契数

    1137. 第 N 个泰波那契数

    题目描述: 

    泰波那契序列 Tn 定义如下: 

    T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2

    给你整数 n,请返回第 n 个泰波那契数 Tn 的值。

     解题思路:

    本题很明显

    1. 状态表示dp【i】为第n个泰波那契数,本题是第一种情况,后面的题目我们会不断遇到1,2,3的情况,我们后面再细讲
    2. 而状态转移方程为题目也直接给了出来, Tn+3 = Tn + Tn+1 + Tn+2,状态转移方程: Tn = Tn -1+ Tn-2 + Tn-3
    3. 初始化(防止越界的情况):本题很明显Tn-3的时候当,n小于3的时候会出现越界的情况,因此我们要提前初始化好dp【0】 ,dp【1】,dp【2】
    4. 填表顺序: 左到右
    5. 返回值;dp【n】

    细节问题: 

    •  当n<3的时候,就不需要进行Tn = Tn -1+ Tn-2 + Tn-3计算因此就可以直接返回

    空间优化问题:

    本题如果我们按照上面的写法的话,就需要开辟一个n+1大小的vector数组dp,当我们在计算第n个位置的时候,我们只需要n-1,n-2,n-3的位置,如果前面还有n-4和n-5都不需要的

    因此我们就可以直接用三个变量a,b,c来优化,使得空间复杂度为o(1)

    解题代码: 

    1. class Solution {
    2. public:
    3. int tribonacci(int n) {
    4. if (n == 0)return 0;
    5. if (n == 1 || n == 2)return 1;
    6. vector<int>dp(n + 1);
    7. dp[0] = 0, dp[1] = 1, dp[2] = 1;
    8. for (int i = 3; i <= n; i++)
    9. dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3];
    10. return dp[n];
    11. }
    12. };

     空间优化后:

    1. class Solution {
    2. public:
    3. int tribonacci(int n) {
    4. if (n == 0)return 0;
    5. if (n == 1 || n == 2)return 1;
    6. int a = 0, b = 1, c = 1;
    7. int d = 0;
    8. for (int i = 3; i <= n; i++)
    9. {
    10. d = a + b + c;
    11. a = b; b = c; c = d;
    12. }
    13. return d;
    14. }
    15. };

    面试题 08.01. 三步问题

    面试题 08.01. 三步问题

    题目描述:

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

     解题思路:

    分析一下题目的意思:

    当从0号台阶到1号台阶,只有1种方法;

    当从0号台阶到2号台阶,我们可以直接从0号台阶蹦到2号台阶,也可以从0-1-2,总共两种解法

    当从0号台阶到3号台阶,我们可以从0号直接蹦到3号台阶,也可以0-1-2-3和0-2-3和0-1-3,总共4种解法

     眼尖的同学这个时候以及发现了状态转移方程了,我们注意一下(以到4号台阶为例):我们可以看成从1号到4的方法数+2号到4号的方法数+3号到4号的方法数

    1. 因此我们的状态表示dp【i】就表示到达第i号台阶的方法数
    2. 状态转移方程:

    此时有的同学会有一个疑问:就是我从i-2号台阶到i号台阶的时候不是有两种情况:

    • i-2到i
    • i-2先到i-1再到i号台阶 

    其实不然:i-2先到i-1的这种情况以及是包含在i-1到i的方法数中

    1. 初始化(防止越界的情况):本题很明显Tn-3的时候当,n小于3的时候会出现越界的情况,因此我们要提前初始化好dp【0】 ,dp【1】,dp【2】
    2. 填表顺序: 左到右
    3. 返回值;dp【n】

     解题代码:

    1. class Solution {
    2. public:
    3. const int MOD=1e9+7;
    4. int waysToStep(int n) {
    5. if(n==1)return 1;
    6. if(n==2)return 2;
    7. if(n==3)return 4;
    8. vector<int>dp(n+1);
    9. dp[1]=1,dp[2]=2,dp[3]=4;
    10. for(int i=4;i<=n;i++)
    11. dp[i]=((dp[i-1]+dp[i-2])%MOD+dp[i-3])%MOD;
    12. return dp[n];
    13. }
    14. };

  • 相关阅读:
    基于Linux 系统聊天室登录与注册实现(03)
    IDEA中Docker相关操作的使用教程
    Sentinel为什么这么强,我扒了扒背后的实现原理
    AIGPT重大升级,界面重新设计,功能更加饱满,用户体验升级
    51单片机音乐喷泉频谱彩灯多功能音乐盒播放器
    基于PHP+MySQL的校园餐厅展示订餐系统
    vue框架学习-----vue简介&vue.js安装&第一个vue程序&部分vue指令
    SpringMVC处理请求流程
    中国人民大学与加拿大女王大学金融硕士——山有顶峰,海有彼岸,一切终有回甘
    每天40min,我们一起用70天稳扎稳打学完《JavaEE初阶》——37/70 第三十七天【复习前端】
  • 原文地址:https://blog.csdn.net/m0_69061857/article/details/134015599