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。

相关推荐
2301_8166602113 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
第一程序员13 小时前
数据工程 pipelines 实践
python·github
励志的小陈13 小时前
数据结构--二叉树知识讲解
数据结构
知行合一。。。13 小时前
Python--05--面向对象(属性,方法)
android·开发语言·python
郝学胜-神的一滴13 小时前
深度学习必学:PyTorch 神经网络参数初始化全攻略(原理 + 代码 + 选择指南)
人工智能·pytorch·python·深度学习·神经网络·机器学习
leobertlan13 小时前
好玩系列:用20元实现快乐保存器
android·人工智能·算法
青梅橘子皮13 小时前
C语言---指针的应用以及一些面试题
c语言·开发语言·算法
笨笨饿13 小时前
#58_万能函数的构造方法:ReLU函数
数据结构·人工智能·stm32·单片机·硬件工程·学习方法
qq_3721542314 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_深海凉_15 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode