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

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

一、题目解析

结合示例我们需要得出第i个泰波那契数的大小,由此我们能得出状态表示,dp[i]表示:第i个泰波那契数。

二、算法解析

根据题目要求我们得出了状态表示,对题目提供的定义式稍作变形就能得到状态转移方程。

原式为:Tn+3 = Tn + Tn+1 + Tn+2,将i替换n,并对下标减3

得到状态转移方程:Ti = Ti-1+ Ti-2 + Ti-3

初始化:根据题目我们需要初始化dp[0] = 0,dp[1] = dp[2] = 1即可,其余的可以通过定义式计算出来。

填表的顺序:例先填dp[4],dp[4] = dp[3] + dp[2] + dp[1],为了避免所需的状态未计算,所以从3开始从左到右依次填入数据进dp表中。

返回值:根据题目,我们只需要返回dp[i]的值即可。 

老规矩,先根据上面的解析去自己实现,链接:1137. 第 N 个泰波那契数 - 力扣(LeetCode)

 三、代码示例

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

我们能知道时间复杂度是O(1),空间复杂度是O(N),下面我们可以用滚动数组对其进行优化,使其空间复杂度为O(1).

四、空间优化

 只需要在刚才代码的基础上,略加修改即可。

代码示例

class Solution {
public:int tribonacci(int n) {//处理边界条件if(n == 0) return 0;if(n == 1 || n == 2) return 1;int a = 0,b = 1,c = 1,d = 0;//空间优化for(int i = 3;i<=n;i++){d = a + b + c;a = b;//赋值更新数据b = c;c = d;}return d;}
};

看到最后,如果对您有所帮助还请留下免费的点赞和收藏把!我们下期再见! 

http://www.xdnf.cn/news/3706.html

相关文章:

  • 【iview】es6变量结构赋值(对象赋值)
  • 【LLaMA-Factory实战】1.3命令行深度操作:YAML配置与多GPU训练全解析
  • 轻量级RTSP服务模块:跨平台低延迟嵌入即用的流媒体引擎
  • 从融智学视域快速回顾世界历史和主要语言文字最初历史证据(列表对照分析比较)
  • Vue实现成绩增删案例
  • C++ 中的继承
  • JSON 处理笔记
  • npm pnpm yarn 设置国内镜像
  • 数据库原理与应用实验二 题目七
  • PowerShell安装Chocolatey
  • 哈希函数详解(SHA-2系列、SHA-3系列、SM3国密)案例:构建简单的区块链——密码学基础
  • Python刷题:流程控制(下)
  • PowerPC架构详解:定义、应用及特点
  • 【PostgreSQL数据分析实战:从数据清洗到可视化全流程】1.1 数据库核心概念与PostgreSQL技术优势
  • C++负载均衡远程调用学习之 Dns-Route关系构建
  • 代码随想录算法训练营Day43
  • 超预期!淘宝闪购提前开放全国全量,联合饿了么扭转外卖战局
  • 美丽天天秒链动2+1源码(新零售商城搭建)
  • P4314 CPU 监控 Solution
  • YOLO旋转目标检测之ONNX模型推理
  • 上位机知识篇---粗细颗粒度
  • P2415集合求和 题解
  • 【Java IO流】字符输入流FileReader、字符输出流FileWriter
  • C++ 动态内存管理详讲
  • 【Java IO流】字节输入流FileInputStream、字节输出流FileOutputStream
  • ICRA 2025 基于触觉反馈的闭环分层控制框架——开放环境下通用门开启的智能规划与操作
  • 【unity游戏开发入门到精通——UGUI】实现精准点击异形或者不规则图片button按钮
  • 字符串的相关方法
  • 【黑马JavaWeb+AI知识梳理】后端Web基础02 - Web基础
  • 街景主观感知全流程(自建数据集+两两对比程序+Trueskill计算评分代码+训练模型+大规模预测)20