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;
};
相关推荐
君义_noip11 小时前
信息学奥赛一本通 1661:有趣的数列 | 洛谷 P3200 [HNOI2009] 有趣的数列
c++·算法·组合数学·信息学奥赛·csp-s
程序员:钧念12 小时前
深度学习与强化学习的区别
人工智能·python·深度学习·算法·transformer·rag
英英_12 小时前
MATLAB数值计算基础教程
数据结构·算法·matlab
一起养小猫13 小时前
LeetCode100天Day14-轮转数组与买卖股票最佳时机
算法·leetcode·职场和发展
hele_two13 小时前
快速幂算法
c++·python·算法
l1t14 小时前
利用DeepSeek将python DLX求解数独程序格式化并改成3.x版本
开发语言·python·算法·数独
jllllyuz14 小时前
基于子集模拟的系统与静态可靠性分析及Matlab优化算法实现
算法·matlab·概率论
程序员-King.14 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
BlockChain88814 小时前
字符串最后一个单词的长度
算法·go
爱吃泡芙的小白白14 小时前
深入解析:2024年AI大模型核心算法与应用全景
人工智能·算法·大模型算法