1137. 第 N 个泰波那契数

泰波那契序列 Tn 定义如下:

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

给你整数 n,请返回第 n 个泰波那契数 Tn 的值。

示例 1:

ini 复制代码
输入: n = 4
输出: 4
解释:
T_3 = 0 + 1 + 1 = 2
T_4 = 1 + 1 + 2 = 4

示例 2:

ini 复制代码
输入: n = 25
输出: 1389537

题解:

js 复制代码
/**
 * @param {number} n
 * @return {number}
 */
// 方法一:动态规划1
var tribonacci = function (n) {
    if (n === 0) {
        return 0;
    }
    if (n <= 2) {
        return 1;
    }
    const dp = [0, 1, 1]
    for (let i = 3; i <= n; i++) {
        dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3]
    }
    return dp[n]
};

只和前三项有关,因此可以使用「滚动数组思想」将空间复杂度优化成 O(1)O(1)O(1)。如下的代码中给出的就是这种实现。

js 复制代码
// 方法一:动态规划2 - 滚动数组
var tribonacci = function (n) {
    if (n === 0) {
        return 0;
    }
    if (n <= 2) {
        return 1;
    }
    let p = 0, q = 0, r = 1, s = 1
    for (let i = 3; i <= n; i++) {
        p = q
        q = r
        r = s
        s = p + q + r;
    }
    return s
};
相关推荐
Liu6288838 分钟前
C++中的工厂模式高级应用
开发语言·c++·算法
AI科技星1 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
条tiao条2 小时前
KMP 算法详解:告别暴力匹配,让字符串匹配 “永不回头”
开发语言·算法
干啥啥不行,秃头第一名2 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
zzh940772 小时前
Gemini 3.1 Pro 硬核推理优化剖析:思维织锦、动态计算与国内实测
算法
2301_807367192 小时前
C++中的解释器模式变体
开发语言·c++·算法
愣头不青3 小时前
617.合并二叉树
java·算法
MIUMIUKK3 小时前
双指针三大例题
算法
灵感__idea3 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法
2301_819414304 小时前
C++与区块链智能合约
开发语言·c++·算法