力扣刷题——509. 斐波那契数

509. 斐波那契数

斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:

F(0) = 0,F(1) = 1

F(n) = F(n - 1) + F(n - 2),其中 n > 1

给定 n ,请计算 F(n) 。

示例 1:

输入:n = 2

输出:1

解释:F(2) = F(1) + F(0) = 1 + 0 = 1

示例 2:

输入:n = 3

输出:2

解释:F(3) = F(2) + F(1) = 1 + 1 = 2

示例 3:

输入:n = 4

输出:3

解释:F(4) = F(3) + F(2) = 2 + 1 = 3

提示:

0 <= n <= 30

实现代码(Python):

python 复制代码
class Solution(object):
    def fib(self, n):
        """
        :type n: int
        :rtype: int
        """
        #排除n = 0 时的边界条件,避免越界否则报错!!
        if n==0:
            return 0
        
        #1.dp[i]的定义为:第i个数的斐波那契数值是dp[i]    
        dp=[0]*(n+1)
        #3.初始化(根据题目)
        dp[0]=0
        dp[1]=1
        #4.遍历顺序
        for i in range(2,n+1):
        		#2.递推公式(已给)
            dp[i]=dp[i-1]+dp[i-2]
        #5.验证
        
        return dp[n]
    

分析

解决动态规划的经典五部曲为:

1.确定dp数组以及下标的含义

2.确定递推公式

3.dp数组应该如何初始化

4.确定遍历序列

5.打印dp数组(举例推导dp数组)

另:其实本题只需要维护两个数值就可以了,不需要记录整个序列

相关推荐
兵慌码乱13 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵15 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio18 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
kisshyshy19 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
用户03321266636720 小时前
使用 Python 从零创建 Word 文档
python
Csvn1 天前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定
后端·python
曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
猿人谷1 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
用户556918817531 天前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维
复杂网络1 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法