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;
};
相关推荐
海的诗篇_1 小时前
移除元素-JavaScript【算法学习day.04】
javascript·学习·算法
自动驾驶小卡1 小时前
A*算法实现原理以及实现步骤(C++)
算法
Unpredictable2221 小时前
【VINS-Mono算法深度解析:边缘化策略、初始化与关键技术】
c++·笔记·算法·ubuntu·计算机视觉
编程绿豆侠1 小时前
力扣HOT100之多维动态规划:1143. 最长公共子序列
算法·leetcode·动态规划
珂朵莉MM1 小时前
2021 RoboCom 世界机器人开发者大赛-高职组(初赛)解题报告 | 珂学家
java·开发语言·人工智能·算法·职场和发展·机器人
fail_to_code2 小时前
递归法的递归函数何时需要返回值
算法
C137的本贾尼2 小时前
(每日一道算法题)二叉树剪枝
算法·机器学习·剪枝
BUG收容所所长4 小时前
栈的奇妙世界:从冰棒到算法的华丽转身
前端·javascript·算法
XRZaaa4 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法