【算法】動態規劃:1137. 第 N 個泰波那契數

1137. 第 N 個泰波那契數

簡單
相關標簽
premium lock icon
相關企業
提示
泰波那契序列 Tn 定義如下:

T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的條件下 Tn+3 = Tn + Tn+1 + Tn+2

給你整數 n,請返回第 n 個泰波那契數 Tn 的值。

示例 1:

輸入:n = 4
輸出:4
解釋:
T_3 = 0 + 1 + 1 = 2
T_4 = 1 + 1 + 2 = 4
示例 2:

輸入:n = 25
輸出:1389537

提示:

0 <= n <= 37
答案保證是一個 32 位整數,即 answer <= 2^31 - 1。
在這里插入圖片描述

在這里插入圖片描述

分析

解題思路
泰波那契數列(Tribonacci)定義:

T? = 0,  
T? = 1,  
T? = 1,  
T? = T??? + T??? + T???  (n ≥ 3)

我們要計算第 n 項 T?。由于 n ≤ 37,直接用動態規劃即可在 O(n) 時間內完成,且可以只用 O(1) 的額外空間(滾動變量)。


方法一:迭代 + 滾動變量(空間 O(1))

維護三個變量 a=T???b=T???c=T???,從 i=3 迭代到 n,每次計算 d = a + b + c,然后滾動更新:

// C++ 實現
class Solution {
public:int tribonacci(int n) {if (n == 0) return 0;if (n <= 2) return 1;       // T1 = T2 = 1int a = 0, b = 1, c = 1;    // 分別對應 T0, T1, T2int d = 0;for (int i = 3; i <= n; ++i) {d = a + b + c;  // 計算 T_ia = b;          // 滾動:下輪 a = T_{i-2}b = c;          //      b = T_{i-1}c = d;          //      c = T_i}return c;}
};
# Python 實現
class Solution:def tribonacci(self, n: int) -> int:if n == 0:return 0if n <= 2:return 1a, b, c = 0, 1, 1  # 對應 T0, T1, T2for _ in range(3, n + 1):a, b, c = b, c, a + b + creturn c
  • 時間復雜度:O(n)
  • 空間復雜度:O(1)

方法二:遞歸 + 備忘錄(空間 O(n))

雖然遞歸更直觀,但不加緩存會產生大量重復子問題。使用哈希表或數組保存已計算的 T?:

// C++ 實現:遞歸 + 備忘錄
class Solution {vector<int> memo;
public:int tribonacci(int n) {memo.assign(n+1, -1);return dfs(n);}int dfs(int i) {if (i == 0) return 0;if (i <= 2) return 1;if (memo[i] != -1) return memo[i];return memo[i] = dfs(i-1) + dfs(i-2) + dfs(i-3);}
};
# Python 實現:遞歸 + 備忘錄
class Solution:def __init__(self):self.memo = {0: 0, 1: 1, 2: 1}def tribonacci(self, n: int) -> int:if n in self.memo:return self.memo[n]self.memo[n] = (self.tribonacci(n-1)+ self.tribonacci(n-2)+ self.tribonacci(n-3))return self.memo[n]
  • 時間復雜度:O(n)
  • 空間復雜度:O(n)(遞歸棧 + 備忘錄)

對于本題,方法一最為簡潔高效,推薦使用滾動變量迭代。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/912443.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/912443.shtml
英文地址,請注明出處:http://en.pswp.cn/news/912443.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[附源碼+數據庫+畢業論文]基于Spring+MyBatis+MySQL+Maven+jsp實現的校園家教兼職信息交流平臺管理系統,推薦!

摘 要 現代經濟快節奏發展以及不斷完善升級的信息化技術&#xff0c;讓傳統數據信息的管理升級為軟件存儲&#xff0c;歸納&#xff0c;集中處理數據信息的管理方式。本校園家教兼職信息交流平臺就是在這樣的大環境下誕生&#xff0c;其可以幫助管理者在短時間內處理完畢龐大的…

vue-33(實踐練習:使用 Nuxt.js 和 SSR 構建一個簡單的博客)

實踐練習:使用 Nuxt.js 和 SSR 構建一個簡單的博客 使用 Nuxt.js 和 SSR 構建一個簡單的博客是鞏固你對服務器端渲染理解以及 Nuxt.js 如何簡化這一過程的好方法。這個練習將帶你完成設置基本博客結構、獲取數據并以用戶友好的格式展示,同時利用 SSR 的優勢來提升 SEO 和性能…

如何在 .Net 7 中使用 MQTT 客戶端

介紹 MQTT&#xff08;消息隊列遙測傳輸&#xff09;是一種輕量級消息傳遞協議&#xff0c;專為資源受限的環境而設計。MQTT 廣泛應用于物聯網 (IoT) 和機器對機器 (M2M) 通信。 本文將討論如何在 .NET 7 中實現 MQTT 消費者。我們將使用 MQTTnet 庫&#xff0c;這是 C# 中的高…

云上攻防—Docker安全容器逃逸特權模式危險掛載

前言 之前分享的是云服務安全&#xff0c;今天開始云原生安全&#xff0c;安全道路依舊很長。 什么是Docker呢&#xff0c;它是開源的容器化平臺&#xff0c;用于開發、部署和運行應用程序。它通過將應用程序及其依賴項打包在輕量級的容器中&#xff0c;實現環境一致性、快速…

2025API 開發工具Apipost 與 Apifox深度對比

在當今數字化時代&#xff0c;API 開發是構建各類軟件應用的關鍵環節。Apipost 和 Apifox 作為兩款知名的 API 開發工具&#xff0c;它們在實際開發場景中表現究竟如何呢&#xff1f;接下來&#xff0c;讓我們從多個功能點進行深入對比。 一、API 設計功能 接口定義與參數設置…

從零開始搭建Windows AI開發環境:QWQ-32B部署+Cursor插件優化實戰

文章目錄 前言1.安裝Ollama2.QwQ-32B模型安裝與運行3.Cursor安裝與配置4. 簡單使用測試5. 調用本地大模型6. 安裝內網穿透7. 配置固定公網地址總結 前言 本方案提出了一種基于Windows系統的智能化開發平臺搭建策略&#xff0c;通過融合Cursor智能編程平臺、Ollama模型運行框架…

PostgreSQL 中,若需顯示 不在 `IN` 子句列表中的數據

在 PostgreSQL 中&#xff0c;若需顯示 不在 IN 子句列表中的數據&#xff0c;可以通過以下方法實現&#xff1a; 方法 1&#xff1a;使用 NOT IN&#xff08;注意 NULL 值&#xff09; 直接篩選不包含在 IN 列表中的記錄&#xff1a; SELECT * FROM your_table WHERE your_c…

嘉訊科技:醫療信息化、數字化、智能化三者之間的關系和區別

隨著技術的不斷發展&#xff0c;醫療行業也在發生著巨大的變化。在這個過程中&#xff0c;醫療信息化、數字化、智能化成為三個重要方向。這些變化不僅帶來了醫療技術的進步&#xff0c;而且大大提高了醫療服務的質量和效率。 一、醫療信息化 醫療信息化是指醫療行業應用信息技…

Windows VMWare Centos Docker部署Springboot應用

接上篇文章&#xff1a;Windows VMWare Centos環境下安裝Docker并配置MySql-CSDN博客文章瀏覽閱讀370次&#xff0c;點贊3次&#xff0c;收藏4次。Windows VMWare Centos環境下安裝Docker并配置MySqlhttps://blog.csdn.net/u013224722/article/details/148928081 一、新建Sprin…

JavaEE-Spring事務和事務的傳播機制

事務 什么是事務 事務是?組操作的集合, 是?個不可分割的操作. 事務會把所有的操作作為?個整體, ?起向數據庫提交或者是撤銷操作請求. 所以這組操作要么同時成功, 要么同時失敗. 為什么需要事務? 事務的操作 Spring 中事務的實現 創建好數據庫后就是配置數據庫相關的配…

共享經濟視域下社群經濟的本質重構:基于開源AI智能名片鏈動2+1模式S2B2C商城小程序源碼的實證研究

摘要&#xff1a;社群經濟在互聯網時代呈現爆發式增長&#xff0c;但傳統社群運營存在情感維系成本高、商業轉化路徑長、技術賦能不足等痛點。本文以共享經濟理論為框架&#xff0c;結合開源AI智能名片鏈動21模式S2B2C商城小程序源碼的技術實踐&#xff0c;提出“思想-資源-機會…

測試方法的分類

靜態測試 核心分類依據&#xff1a;根據是否執行程序分為靜態測試和動態測試 靜態測試方法 執行特征&#xff1a;不運行被測程序&#xff0c;通過人工檢查或工具分析進行測試 測試對象&#xff1a;主要針對文檔&#xff08;包括需求文檔、設計文檔等&#xff09;和源代碼 實…

查看CPU支持的指令集和特性

1&#xff09;gcc -c -Q -marchnative --helptarget 2&#xff09;結果 The following options are target specific: -m128bit-long-double [enabled] -m16 [disabled] -m32 [disabled…

【大模型應用開發】Unity結合大模型實現智能問答功能

零、最終效果 Unity結合大模型實現智能問答功能 一、文本自動換行效果 新建一個Text文本&#xff0c;設置文本的最大寬度 然后添加Content Size Fitter組件&#xff0c;Vertical Fit選擇Preferred Size 二、背景隨文本長度變化效果 新建一個Image作為文本的背景&#xff0…

Python爬蟲-爬取汽車之家全部汽車品牌及車型數據

前言 本文是該專欄的第64篇,后面會持續分享python爬蟲干貨知識,記得關注。 本文,筆者將基于汽車之家平臺,通過Python獲取全部的“汽車品牌以及車型”數據。 廢話不多說,具體實現思路和詳細邏輯,筆者將在正文結合完整代碼進行詳細介紹。接下來,跟著筆者直接往下看正文詳…

簽名組件:uniapp 簽名組件開發,兼容小程序、H5、App等 電子簽名

描述 H5&#xff1a;1. 模擬橫屏。2. 提示信息、模擬態也通過模擬橫屏顯示 小程序&#xff1a;1. 自動橫屏展示 APP&#xff1a;1. 自動橫屏展示 rn-signature 個性簽名組件 組件名 rn-signature 簽名組件兼容H5、APP、小程序。橫屏簽名效果。 效果展示 h5端 小程序端 APP 端…

第10.4篇 使用預訓練的目標檢測網絡

在PyTorch提供的已經訓練好的圖像目標檢測中&#xff0c;均是R-CNN系列 的網絡&#xff0c;并且針對目標檢測和人體關鍵點檢測分別提供了容易調用的方 法。針對目標檢測的網絡&#xff0c;輸入圖像均要求使用相同的預處理方式&#xff0c;即先將每張圖像的像素值預處理到0~1之…

基于開源鏈動2+1模式AI智能名片S2B2C商城小程序源碼的運營機制沉淀與規范構建研究

摘要&#xff1a;在數字化商業生態中&#xff0c;運營機制的沉淀與規范構建是企業實現可持續增長的核心命題。本文以開源鏈動21模式、AI智能名片、S2B2C商城小程序源碼為技術基座&#xff0c;提出“機制設計-數據沉淀-規范生成-迭代優化”的四階閉環模型。通過某健康食品品牌的…

js代碼05

題目 好的&#xff0c;我們進入異步編程的“終極形態”&#xff1a;async/await。 async/await 是在 ES2017 (ES8) 中引入的&#xff0c;它并不是一個全新的功能&#xff0c;而是建立在 Promise 之上的語法糖 (Syntactic Sugar)。它的目標是讓我們能夠以一種看似同步、更符合…

PyTorch里.pt和.pth的區別

在PyTorch中&#xff0c;.pt和.pth文件均用于保存模型&#xff0c;但兩者在設計初衷、存儲內容和使用場景上存在差異。以下是詳細對比&#xff1a; 1. 核心區別 特性.pt文件.pth文件存儲內容完整模型&#xff08;結構參數優化器狀態等&#xff09;僅模型參數&#xff08;state…