当前位置: 首页 > news >正文

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

示意图:

索引: 0  1  2  3  4
值:   0  1  1  2  4↑  ↑
时间复杂度和空间复杂度
  • O(n): 需要从i=3计算到i=n,一共执行n-2次循环
  • 每次循环是常数时间操作(简单加法)
  • O(n): 需要一个长度为n+1的dp数组存储所有计算结果
代码
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];}
};

相关文章:

  • 学习黑客色即是空
  • python使用cv2在图片上标点
  • 二、shell脚本--变量与数据类型
  • c++_2011 NOIP 普及组 (1)
  • WebSocket分布式实现方案
  • 【LLaMA-Factory实战】1.3命令行深度操作:YAML配置与多GPU训练全解析
  • 数据库 1.0
  • wpf CommandParameter 传递MouseWheelEventArgs参数 ,用 MvvmLight 实现
  • 里氏替换原则(LSP)
  • Java 网络安全新技术:构建面向未来的防御体系
  • 强化学习--2.数学
  • 【Java学习】通配符?
  • 内存性能测试方法
  • 如何通过文理工三类AI助理赋能HI,从而,颠覆“隔行如隔山”的旧观念和“十万小时定律”的成长限制
  • 穿越数据森林与网络迷宫:树与图上动态规划实战指南
  • 【CF】Day50——Codeforces Round 960 (Div. 2) BCD
  • AVFormatContext 再分析零
  • 《告别试错式开发:TDD的精准质量锻造术》
  • Vivado FPGA 开发 | 创建工程 / 仿真 / 烧录
  • 分布式事务解决方案
  • 外交部:印巴都表示不希望局势升级,望双方都能保持冷静克制
  • 国新办将于5月8日10时就《民营经济促进法》有关情况举行新闻发布会
  • 央行行长详解降准:将释放长期流动性1万亿,整体存款准备金率平均水平降至6.2%
  • 线下无理由退货怎样操作?线上线下监管有何不同?市场监管总局回应
  • 人们为何热衷谈论八卦?
  • 伊朗港口爆炸事故遇难人数最终确定为57人