OJ--第N个泰波那契数列

1137. 第 N 个泰波那契数 - 力扣(LeetCode)

1 题干部分

2 拆解

1 状态表示:dp[i]

2 状态转移方程:dp[i]=dp[i-1]+dp[i-2]+dp[i-3]

3 初始化:让dp[0]=0,dp[1]=dp[2]=1

4 填表顺序:从dp[3]开始填从左往右填

5 返回值:dp[n]即为返回的数列Tn

3 思路及代码实现

cpp 复制代码
class Solution {
public:
   public:
    int tribonacci(int n) {
        if(n==0) return 0;
        if(n==1||n==2) return 1;
    //建表
       vector<int> dp(n+1);
    //初始化
       dp[0]=0, dp[1]=dp[2]=1;
    //填表   
       for(int i=3;i<n+1;i++)
        dp[i]=dp[i-1]+dp[i-2]+dp[i-3];

    //返回
       return dp[n];
    }
};

4 空间优化

思路:

利用滚动数组来节省dp表的空间开销

创建四个变量,让其位于后面的三个数据向前不断滚动

代码实现:

cpp 复制代码
class solution{
public:
int tribonacci(int n) {
       if(n==0) return 0;
       if(n==1||n==2) return 1;
       in
    int a=0,b=1,c=1,d=0;
   
    for(int i=3;i<n+1;i++)
   {
    d=a+b+c;
    a=b,b=c,c=d; 
   }
      return d;
};
相关推荐
晓1313几秒前
第六章 【C语言篇:结构体&位运算】 结构体、位运算全面解析
c语言·算法
iAkuya6 分钟前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展
梵刹古音9 分钟前
【C语言】 指针与数据结构操作
c语言·数据结构·算法
VT.馒头15 分钟前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
CoderCodingNo2 小时前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
大闲在人2 小时前
7. 供应链与制造过程术语:“周期时间”
算法·供应链管理·智能制造·工业工程
小熳芋2 小时前
443. 压缩字符串-python-双指针
算法
2501_924878732 小时前
数据智能驱动进化:AdAgent 多触点归因与自我学习机制详解
人工智能·逻辑回归·动态规划
Charlie_lll2 小时前
力扣解题-移动零
后端·算法·leetcode
chaser&upper2 小时前
矩阵革命:在 AtomGit 解码 CANN ops-nn 如何构建 AIGC 的“线性基石”
程序人生·算法