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

凡科网免费建站门户网站建设中标结果

凡科网免费建站,门户网站建设中标结果,杭州企业网站定制,手机网站怎么做seo动态规划与滚动数组优化:LeetCode 1137.第 N 个泰波那契数 1. 题目链接 LeetCode 1137. 第 N 个泰波那契数 题目要求:计算第 n 个泰波那契数(Tribonacci Number)。泰波那契数列的定义如下: T0 0, T1 1, T2 1Tn3 …

动态规划与滚动数组优化:LeetCode 1137.第 N 个泰波那契数


1. 题目链接

LeetCode 1137. 第 N 个泰波那契数
题目要求:计算第 n 个泰波那契数(Tribonacci Number)。泰波那契数列的定义如下:

  • T0 = 0, T1 = 1, T2 = 1
  • Tn+3 = Tn + Tn+1 + Tn+2(当 n ≥ 0 时)

2. 题目描述
  • 输入:整数 n(例如 n = 4)。
  • 输出:第 n 个泰波那契数(例如 T4 = 4)。
  • 约束条件
    • 0 ≤ n ≤ 37
    • 结果保证在 32 位整数范围内(即 ≤ 2^31 - 1)。

3. 示例分析

示例 1
输入:n = 4
输出:4
分步计算

  • T0 = 0
  • T1 = 1
  • T2 = 1
  • T3 = T0 + T1 + T2 = 0 + 1 + 1 = 2
  • T4 = T1 + T2 + T3 = 1 + 1 + 2 = 4

示例 2
输入:n = 25
输出:1389537


4. 算法思路
动态规划与滚动数组优化
  1. 问题特性

    • 泰波那契数的递推公式依赖前三个状态,适合用动态规划解决。
    • 直接递归会重复计算子问题(时间复杂度 O(3^n)),需优化。
  2. 动态规划递推

    • 定义状态 dp[i] 表示第 i 个泰波那契数。
    • 递推公式:dp[i] = dp[i-1] + dp[i-2] + dp[i-3]
  3. 滚动数组优化

    • 观察发现,计算 dp[i] 仅需前三个值 dp[i-1]dp[i-2]dp[i-3]
    • 用三个变量 dp1dp2dp3 代替数组,空间复杂度从 O(n) 降为 O(1)
具体步骤
  1. 初始化
    • T0 = 0, T1 = 1, T2 = 1
  2. 递推计算
    • i = 3n,依次更新当前值 tn = dp1 + dp2 + dp3
    • 滚动更新变量:dp1 = dp2, dp2 = dp3, dp3 = tn

5. 边界条件与注意事项
  1. 边界处理

    • n = 0 时直接返回 0
    • n = 1n = 2 时直接返回 1
  2. 变量初始化顺序

    • dp1dp2dp3 分别对应 T0T1T2
  3. 循环范围

    • n < 3,直接返回初始值,无需进入循环。
  4. 整数溢出问题

    • 题目保证结果在 32 位整数范围内,无需额外处理。
  5. 时间复杂度

    • O(n),遍历 n-2 次。

6. 代码实现与逐行解析
class Solution {
public:int tribonacci(int n) {if (n == 0) return 0;        // 边界条件:T0 = 0if (n == 1 || n == 2) return 1; // 边界条件:T1=T2=1// 初始化滚动数组(对应 T0, T1, T2)int dp1 = 0, dp2 = 1, dp3 = 1, tn = 0;for (int i = 3; i <= n; i++) {tn = dp1 + dp2 + dp3;    // 计算当前值 T_i// 滚动更新:dp1 -> T_{i-2}, dp2 -> T_{i-1}, dp3 -> T_idp1 = dp2;dp2 = dp3;dp3 = tn;}return tn; // 返回 T_n}
};
代码解析
  1. 边界处理

    • n = 0n = 1n = 2 直接返回预定义值。
  2. 变量初始化

    • dp1 = 0(对应 T0),dp2 = 1(对应 T1),dp3 = 1(对应 T2)。
  3. 循环递推

    • i = 3 开始,计算 tn = dp1 + dp2 + dp3(即 T_i)。
    • 更新变量:
      • dp1 更新为原来的 dp2(即 T_{i-2} = T_{i-1})。
      • dp2 更新为原来的 dp3(即 T_{i-1} = T_i)。
      • dp3 更新为 tn(即 T_i)。
  4. 返回值

    • 循环结束时,tn 即为 T_n

总结

通过滚动数组优化,将动态规划的空间复杂度从 O(n) 降至 O(1),同时保持了时间效率。该算法高效解决了泰波那契数的计算问题,适用于大规模 n 的场景(尽管题目约束 n ≤ 37)。此方法可推广至其他类似递推问题(如斐波那契数列、爬楼梯问题等),核心在于识别状态依赖关系并优化空间使用。


文章转载自:

http://on4Wt6tP.nyqnk.cn
http://X75iimwI.nyqnk.cn
http://hNeGi2pa.nyqnk.cn
http://OOUN68JB.nyqnk.cn
http://eT5moftf.nyqnk.cn
http://EoJFiDyi.nyqnk.cn
http://ckZbb1kt.nyqnk.cn
http://YEGaL0Ea.nyqnk.cn
http://IRrzd5AM.nyqnk.cn
http://zSYQX5Qm.nyqnk.cn
http://pIS6Rxec.nyqnk.cn
http://CdW6i2ZN.nyqnk.cn
http://5CD9FYxB.nyqnk.cn
http://pzC0Bh9x.nyqnk.cn
http://BpzMRTBo.nyqnk.cn
http://sIyJ3CpY.nyqnk.cn
http://bEa4pK2V.nyqnk.cn
http://bZdVLUP8.nyqnk.cn
http://xWKlgs0i.nyqnk.cn
http://IeiDILlH.nyqnk.cn
http://MF2BLfPt.nyqnk.cn
http://bc3jdI6l.nyqnk.cn
http://LjSwG8em.nyqnk.cn
http://V2vj7sSE.nyqnk.cn
http://YrgZbT4d.nyqnk.cn
http://5rs607ad.nyqnk.cn
http://4gxZWtoB.nyqnk.cn
http://vYMBd7Gb.nyqnk.cn
http://XStH5GfL.nyqnk.cn
http://xMFTJ1j6.nyqnk.cn
http://www.dtcms.com/wzjs/732848.html

相关文章:

  • 番禺手机网站制作推广营销网站文章去那找
  • 一个虚拟主机如何建多个网站代码企业形象设计英文
  • 上海免费网站建设咨询百度网盘app手机版
  • 旅游网站建设经济评价网站备案号如何查找
  • 网站建设仟金手指专业12赣州九一人才网
  • 眼镜企业网站建设方案网站建设细节差异化
  • 唐山建设网站的网站十字绣网站开发
  • 网站开发项目文档做网站找那些公司
  • 德州做网站网站在线建设方案
  • 泰安网站建设如何中低端网站建设客户网
  • 网站上传模板后商业网站域名后缀
  • 学校网站建设的作用公司测名网
  • 汕头多语种网站制作怎么做查询数据输入的网站
  • 工业和信息化部网站备案查询广告设计app免费
  • 做网站的字体大小有没有类似wordpress
  • 河间做网站的公司电子硬件工程师培训机构
  • 最新免费网站源码资源网站人工智能网站应怎么做
  • phpcms 怎么做视频网站怎么选择郑州网站建设
  • 制作链接的小程序怎么看网站做没做seo
  • 内存做硬盘缓存软件网站建立充电站需要多少钱
  • 自己切片视频做网站网站备案资质
  • 广州站西手表公司简介50字
  • 站酷设计网页版怎么开发自己的商城
  • 网站制作顺序网站怎么做微信接口
  • 网站开发公司有哪些网站开发要注意安全性
  • 东莞东城做网站公司快速建设企业门户网站
  • python做网站的案例宣城市网站集约化建设
  • 手机便宜电商网站建设金融行业网站模板
  • 公益广告不浪费水网站怎么做长沙有家具网站建设的吗
  • 网站建设需要缴纳印花税么建设会计协会网站