python泰波那契序列(leetcode)
2021/12/5 14:17:13
本文主要是介绍python泰波那契序列(leetcode),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
泰波那契序列Tn定义如下:
t0 = 0, t1 = 1, t2 = 1, 且在n >= 0 的条件下tn+3 = tn + tn+1 + tn+2
给你整数n,请返回第n个泰波那契数tn 的值
当前项等于前三项之和
解法一 暴力递归
代码如下:
class Solution: def tribonacci(self, n: int) -> int: if n == 0: return 0 if n == 1 or n == 2: return 1 return self.tribonacci(n - 3) + self.tribonacci(n - 2) + self.tribonacci(n - 1)
解法二 动态规划,其实就是对递归结果进行缓存,减少重复计算。
代码如下:
class Solution: def tribonacci(self, n: int) -> int: dp = {i:0 for i in range(n+1)} dp[1] = dp[2] =1 if n <=2: return dp[n] for i in range(3, n + 1): dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3] return dp[n]
解法三 压缩空间,使用三个变量
class Solution03: def tribonacci(self, n): a,b,c = 0,1,1 for i in range(n): a,b,c = b,c,a+b+c return a
这篇关于python泰波那契序列(leetcode)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-03用FastAPI掌握Python异步IO:轻松实现高并发网络请求处理
- 2025-01-02封装学习:Python面向对象编程基础教程
- 2024-12-28Python编程基础教程
- 2024-12-27Python编程入门指南
- 2024-12-27Python编程基础
- 2024-12-27Python编程基础教程
- 2024-12-27Python编程基础指南
- 2024-12-24Python编程入门指南
- 2024-12-24Python编程基础入门
- 2024-12-24Python编程基础:变量与数据类型