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

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

相关推荐
科雷软件测试2 小时前
使用python+Midscene.js AI驱动打造企业级WEB自动化解决方案
前端·javascript·python
星越华夏2 小时前
python——三角函数用法
开发语言·python
We་ct2 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣3 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
gmaajt3 小时前
mysql如何检查数据库表是否存在损坏_使用CHECK TABLE命令修复
jvm·数据库·python
hipolymers3 小时前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
heRs BART3 小时前
【Flask】四、flask连接并操作数据库
数据库·python·flask
PyHaVolask4 小时前
Python 爬虫进阶:直接请求 JSON 接口与开发者工具使用
爬虫·python·请求头·反爬·json接口·chrome开发者工具