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

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 思路及代码实现

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表的空间开销

创建四个变量,让其位于后面的三个数据向前不断滚动

代码实现:

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;
};

相关文章:

  • 钢板矫平机:重塑材料加工新标杆
  • 刻意练习:如何从新手到大师
  • VS Code-i18n Ally国际化插件
  • Firebase崩溃:DialogFragment/BottomSheetDialogFragment缺乏无参构造函数
  • 智能指针和STL库学习思维导图和练习
  • 4.7学习总结 java集合进阶
  • 信息系统项目管理师-第十二章-项目质量管理
  • 搭建复现环境
  • 06.unity 游戏开发-unity2D工程的创建及使用方式和区别
  • 基础知识补充篇:认识区块链浏览器
  • 【C++算法】49.分治_归并_计算右侧小于当前元素的个数
  • 免费Deepseek-v3接口实现Browser-Use Web UI:浏览器自动化本地模拟抓取数据实录
  • 如何为多个条件构建 Bson 过滤器
  • 蓝桥杯python组备赛(记录个人模板)
  • 【实践总结】如何编写“多角色适配”的高质量技术文档?
  • HTTP 教程 : 从 0 到 1 全面指南 教程【全文三万字保姆级详细讲解】
  • DiffSynth-Studio-视频的风格转换 CUDA日志
  • OpenCV--图像边缘检测
  • 临床 不等于 医学-《分析模式》漫谈52
  • 企业落地AI难的隐形枷锁-正是数据问题
  • 微信网站结构/怎么让百度收录我的网站
  • 建设外包网站/注册google账号
  • 泰国清迈房产网站大全/百度推广一天费用200
  • 句容网站建设/什么关键词可以搜到那种
  • 网站个人简介怎么做/站长工具海角
  • 网站开发功能需求清单/优化大师官方免费