LeetCode in Python 509. Fibonacci Number (斐波那契数)

斐波那契数实现方式有多种方法,最容易理解的为递归法,也可使用动态规划降低时间复杂度,本文给出递归法和动态规划两种方法的代码实现。

示例:

图1 斐波那契数输入输出示例

方法一:递归法

代码:

python 复制代码
class Solution:
    def fib(self, n):
        if n == 0 or n == 1:
            return n
        else:
            return self.fib(n - 1) + self.fib(n - 2)

方法二:动态规划法

代码:

python 复制代码
class Solution:
    def fib(self, n):
        n1, n2 = 0, 1
        for _ in range(n):
            n1, n2 = n2, n1 + n2
        return n1

解释:

1)求f(n)需要计算n-1次,例如计算f(4),需要计算f(4)、f(3)和f(2),故循环n次后取保存上一次计算结果的n1。

相关推荐
知彼解己4 分钟前
字符串大数相加:从初稿到优化的思路演进
java·开发语言·算法
好多1710 分钟前
《JVM如何排查OOM》
开发语言·jvm·python
学计算机的27 分钟前
Python:OpenCV 教程
开发语言·python
haing201933 分钟前
使用deboor法计算三次B样条曲线在参数为u处的位置的方法介绍
算法·b样条曲线·deboor
qq_3521095235 分钟前
旋转数字矩阵 od
算法
咚咚锵咚咚锵36 分钟前
DrissionPage的学习
前端·python·学习
大阳12336 分钟前
51单片机4(温度传感器DS18B20)
开发语言·单片机·嵌入式硬件·算法·51单片机
阿加犀智能37 分钟前
使用Langchain生成本地rag知识库并搭载大模型
服务器·python·langchain
iナナ38 分钟前
Java优选算法——二分查找
数据结构·算法·leetcode
朱自清的诗.1 小时前
使用python脚本储存mosquito服务器数据到sqlite
python·单片机·sqlite·esp32