python-leetcode-第 N 个泰波那契数

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

解法 1:递归(O(3^n),不推荐)

递归直接按照数学定义实现,但时间复杂度高,不适合大 n。

python 复制代码
class Solution:
    def tribonacci(self, n: int) -> int:
        if n == 0:
            return 0
        elif n == 1 or n == 2:
            return 1
        return self.tribonacci(n - 1) + self.tribonacci(n - 2) + self.tribonacci(n - 3)

缺点 :大量重复计算,时间复杂度 O(3^n),n 较大时会超时。

解法 2:动态规划(O(n),空间 O(n))

使用数组存储计算结果,按顺序计算。

python 复制代码
class Solution:
    def tribonacci(self, n: int) -> int:
        if n == 0:
            return 0
        if n == 1 or n == 2:
            return 1
        dp = [0] * (n + 1)
        dp[1] = dp[2] = 1
        for i in range(3, n + 1):
            dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3]
        return dp[n]

优点 :时间复杂度 O(n) ,比递归更快。

⚠️ 缺点 :空间复杂度 O(n)

解法 3:迭代(O(n),空间 O(1))

只存储 前三个变量,减少空间占用。

python 复制代码
class Solution:
    def tribonacci(self, n: int) -> int:
        if n == 0:
            return 0
        if n == 1 or n == 2:
            return 1
        a, b, c = 0, 1, 1
        for _ in range(n - 2):
            a, b, c = b, c, a + b + c
        return c

优点 :时间复杂度 O(n) ,空间复杂度 O(1),适合大 n。

相关推荐
萧毅寒2 小时前
leetcode第40题组合总和Ⅱ
算法·leetcode·职场和发展
BingLin-Liu2 小时前
蓝桥杯备考:DFS之选数问题
职场和发展·蓝桥杯·深度优先
_extraordinary_2 小时前
动态规划刷题
算法·动态规划
萌の鱼2 小时前
leetcode 48. 旋转图像
数据结构·c++·算法·leetcode
数据攻城小狮子3 小时前
深入剖析 OpenCV:全面掌握基础操作、图像处理算法与特征匹配
图像处理·python·opencv·算法·计算机视觉
xinghuitunan3 小时前
奖学金(acwing)c++
算法
机器学习之心3 小时前
分类预测 | Matlab实现CPO-SVM冠豪猪算法优化支持向量机多特征分类预测
算法·matlab·分类·cpo-svm
MZWeiei3 小时前
算法:判断链表是否有环
算法·链表·c#
boligongzhu3 小时前
LeetCode 873. Length of Longest Fibonacci Subsequence(2025/2/27每日一题)
算法·leetcode·职场和发展
tt5555555555554 小时前
每日一题——接雨水
数据结构·笔记·学习·算法