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;
};
相关推荐
luckycoding1 分钟前
1631. 最小体力消耗路径
数据结构·算法·leetcode
.YY001.5 分钟前
数据结构第一轮复习--第七章查找(包含课程代码)
数据结构·算法
LuckyLay14 分钟前
LeetCode算法题(Go语言实现)_30
算法·leetcode·golang
对方正在长头发丿15 分钟前
P1162 填涂颜色(BFS)
数据结构·c++·算法·蓝桥杯·宽度优先
MeyrlNotFound20 分钟前
杂谈:抖音双塔召回模型:亿级内容分发的数学魔法
算法
不爱学英文的码字机器24 分钟前
隐私计算的崛起:数据安全的未来守护者
服务器·算法
菜就多练,以前是以前,现在是现在28 分钟前
Codeforces Round 1000 (Div. 2)
数据结构·c++·算法
Lenyiin1 小时前
2181、合并零之间的节点
c++·算法·leetcode·链表
gentle_ice1 小时前
找树左下角的值(DFS 深度优先搜索)| LeetCode 513
数据结构·算法·leetcode·深度优先
菜鸡中的奋斗鸡→挣扎鸡2 小时前
总结:查找子字符串出现次数
c++·算法·蓝桥杯