Python实现斐波那契数列之青铜,白银,黄金及铂金版本

斐波那契数列(Fibonacci sequence) ,又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21 ......。


一、青铜(纯递归)

python 复制代码
def fib(num: int):
    if num == 0: return 0
    elif num == 1: return 1
    else: return fib(num - 1) + fib(num - 2)

print(fib(10)) # 55
  • 每次调用都会触发两个子调用,导致调用树是一个二叉树:

    scss 复制代码
    fib(5)
    ├── fib(4)
    │   ├── fib(3)
    │   │   ├── ...
    └── fib(3)
  • 时间复杂度 O(2ⁿ)

    • 每层都递归两次,重复计算非常严重。
  • 空间复杂度 O(n)

    • 函数调用栈最大深度为 n

二、白银(记忆化递归)

python 复制代码
def fib(num: int, memo = { 0: 0, 1: 1 }):
    if num in memo: return memo[num]
    memo[num] = fib(num - 1, memo) + fib(num - 2, memo)
    return memo[num]

print(fib(50)) # 12586269025
  • 使用了"备忘录"缓存中间结果,避免重复计算。

  • 时间复杂度 O(n)

    • 每个数字最多只计算一次。
  • 空间复杂度 O(n)

    • 存储 memo 字典,同时递归调用栈也是 O(n)。

三、黄金(循环迭代)

python 复制代码
def fib(num: int):
    if num == 0: return 0
    a, b = 0, 1
    for _ in range(2, num + 1):
        a, b = b, a + b
    return b

print(fib(50)) # 12586269025
  • 使用变量滑窗 a, b 来不断推导下一个数。

  • 时间复杂度 O(n)

    • 只需循环一次。
  • 空间复杂度 O(1)

    • 只用两个变量 ab

四、铂金(矩阵快速幂法)

python 复制代码
def matrix_mult(a, b):
    return [
        [a[0][0]*b[0][0] + a[0][1]*b[1][0],
         a[0][0]*b[0][1] + a[0][1]*b[1][1]],
        [a[1][0]*b[0][0] + a[1][1]*b[1][0],
         a[1][0]*b[0][1] + a[1][1]*b[1][1]]
    ]

def matrix_pow(mat, power):
    result = [[1, 0], [0, 1]]  # 单位矩阵
    while power > 0:
        if power % 2 == 1:
            result = matrix_mult(result, mat)
        mat = matrix_mult(mat, mat)
        power //= 2
    return result

def fib(n: int):
    if n == 0: return 0
    base = [[1, 1], [1, 0]]
    result = matrix_pow(base, n - 1)
    return result[0][0]

print(fib(50)) # 12586269025

五、总结建议

等级 方法 时间复杂度 空间复杂度 优缺点简述
青铜 递归 ❌ O(2ⁿ) O(n) 极慢,仅用于教学展示,重复子问题多
白银 记忆化递归 ✅ O(n) O(n) 快速,但使用了递归 + 额外内存开销
黄金 迭代(循环) ✅ O(n) ✅ O(1) 最快、最省内存、适合生产环境
铂金 矩阵快速幂 ✅ O(log n) ✅ O(1) 超快、最省内存、适合算法竞赛、海量计算

好了,今天就分享到这,Bye~~

相关推荐
2501_924952691 分钟前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
2401_891482174 分钟前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
2401_851272994 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
小陈的进阶之路9 分钟前
requests接口自动化测试
python
Yuer202511 分钟前
EDCA OS体系下的:QAS v0.1 实验框架(Python 版)
python·ai量化·edca os
一招定胜负15 分钟前
【实战】Python + 讯飞语音识别 + 通义千问:课堂视频自动转结构化教学数据
python·音视频·语音识别
小陈工18 分钟前
Docker容器化部署Python应用——从开发到生产的全流程
运维·开发语言·python·docker·云原生·容器·数据挖掘
代码方舟19 分钟前
Java金融风控实战:集成天远二手车估值API构建车贷抵押资产核验系统
java·开发语言·python·自动化
码踏樱花20 分钟前
PyCharm专业版Win/mac/Linux 2017-2025多版本安装教程【长期使用】
ide·python·pycharm
2401_8463416521 分钟前
使用Python进行网络设备自动配置
jvm·数据库·python