力扣刷题——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数组)

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

相关推荐
吃好睡好便好11 小时前
在Matlab中绘制马鞍函数曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
wa的一声哭了11 小时前
Mit6.s081 Interrupts and device driver(中断和设备驱动)
linux·服务器·arm开发·数据库·python·gpt·算法
测试员周周11 小时前
【Appium 系列】第01节-Appium 是什么 — 移动端自动化的行业标准
开发语言·人工智能·python·功能测试·appium·自动化·测试用例
前端小超人rui11 小时前
Jupyter 介绍
ide·python·jupyter
码界筑梦坊11 小时前
117-基于Python的印度犯罪数据可视化分析系统
开发语言·python·mysql·信息可视化·毕业设计·echarts·fastapi
您^_^11 小时前
Python CosyVoice项目遭遇 Windows TxF WinError 6714 的深度排查与修复指南
windows·python·winerror 6714
luyun02020211 小时前
实用小工具,吾爱出品
开发语言·c++·算法
Gerardisite11 小时前
企业微信智能客服开发实战:API自动回复指南
java·开发语言·python·机器人·企业微信
NNYSJYKJ11 小时前
K12 学习常见问题破解:脑能思维链的算法与教育应用
学习·算法
毋语天11 小时前
Claude Code 完整安装与配置指南(含 CC-Switch 多供应商切换工具)
后端·python·ai编程