LeetCode - 1137.第N个泰波那契数

目录

题目

解法

动态规划解法

核心思想

执行流程

具体例子

时间复杂度和空间复杂度

代码


题目

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

解法

动态规划解法

核心思想

动态规划是一种通过将复杂问题分解为更小子问题来解决的算法方法。我将用第N个泰波那契数来演示这个概念。

泰波那契序列是斐波那契序列的变种,定义为:

  • T(0) = 0
  • T(1) = 1
  • T(2) = 1
  • T(n) = T(n-1) + T(n-2) + T(n-3) (n > 2)

动态规划的核心特点:

  1. 重叠子问题:相同子问题多次计算
  2. 最优子结构:问题的最优解包含子问题的最优解
  3. 状态转移:当前状态依赖于前面的状态
  4. 有明确的递推关系:T(n) = T(n-1) + T(n-2) + T(n-3)

通过存储已解决的子问题结果,动态规划避免了递归方法的重复计算,大大提高了效率。

执行流程
  • 边界条件处理:直接返回T(0)=0, T(1)=1, T(2)=1的结果
  • 创建DP表:建立大小为n+1的数组存储中间结果
  • 初始化:设置dp[0]=0, dp[1]=1, dp[2]=1
  • 状态转移:从i=3开始,使用公式dp[i] = dp[i-1] + dp[i-2] + dp[i-3]填表
  • 返回结果:dp[n]即为所求
具体例子

计算T(4)的过程:

  • 检查:n=4,不是边界情况
  • 创建dp表:dp[0...4]
  • 初始化:dp[0]=0, dp[1]=1, dp[2]=1
  • 填表:
    • i=3: dp[3] = dp[2] + dp[1] + dp[0] = 1 + 1 + 0 = 2
    • i=4: dp[4] = dp[3] + dp[2] + dp[1] = 2 + 1 + 1 = 4
  • 返回dp[4] = 4

示意图:

cpp 复制代码
索引: 0  1  2  3  4
值:   0  1  1  2  4
               ↑  ↑
时间复杂度和空间复杂度
  • O(n): 需要从i=3计算到i=n,一共执行n-2次循环
  • 每次循环是常数时间操作(简单加法)
  • O(n): 需要一个长度为n+1的dp数组存储所有计算结果
代码
cpp 复制代码
class Solution {
public:
    int tribonacci(int n) {
        //1.创建dp表
        //2.初始化
        //3.填表
        //4.返回值

        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;i++)
        {
            dp[i] = dp[i-1] + dp[i-2] + dp[i-3];
        }

        return dp[n];
    }
};
相关推荐
Chandler241 小时前
LeetCode:DP-回文串问题
算法·leetcode·动态规划
Ctrl С2 小时前
[三分钟学算法]分治-快速排序-最小的K个数:设计一个算法,找出数组中最小的k个数。以任意顺序返回这k个数均可。
java·数据结构·算法·leetcode
_Itachi__3 小时前
LeetCode 热题 100 54. 螺旋矩阵
算法·leetcode·矩阵
八股文领域大手子3 小时前
第 7 篇:跳表 (Skip List):简单务实的概率性选手
java·数据结构·windows·算法·leetcode·链表·动态规划
心.c4 小时前
最小单调子序列的长度+联通最小乘积
数据结构·c++·算法·leetcode
GGBondlctrl5 小时前
【leetcode】队列 + 宽搜,树形结构层序遍历的基础与变化
算法·leetcode·n叉树层序遍历·二叉树锯齿形遍历·二叉树最大宽度
GalaxyPokemon5 小时前
LeetCode - 19.删除链表的倒数第N个结点
算法·leetcode·链表
蒟蒻小袁6 小时前
力扣面试150题--相同的树
算法·leetcode·职场和发展
wang__123006 小时前
力扣1128题解
算法·leetcode·职场和发展
星沁城7 小时前
133. 克隆图
java·数据结构·算法·leetcode