[动态规划]斐波那契数列

[动态规划]斐波那契数列

文章目录

动态规划五步曲

动态规划理论基础 | 代码随想录

对于动态规划问题,我将拆解为如下五步曲,这五步都搞清楚了,才能说把动态规划真的掌握了!

  1. 确定dp数组(dp table)以及下标的含义
  2. 确定递推公式
  3. dp数组如何初始化
  4. 确定遍历顺序
  5. 举例推导dp数组
  • 为什么要先确定递推公式,然后在考虑初始化呢?因为一些情况是递推公式决定了dp数组要如何初始化!
  • 动态规划应该如何debug?把dp数组打印出来,看看究竟是不是按照自己思路推导的!

斐波那契数列

题目描述

题目链接:509. 斐波那契数 - 力扣(LeetCode)

动态规划五步曲

1.确定dp[i]含义

dp[i]表示第i个斐波那契数,如dp[0]=1,dp[1]=1,dp[2]=2,dp[3]=3。

2.递推公式

根据斐波那契额数列的定义可以知递推公式为:dp[i]=dp[i-1]+dp[i-2]。

3.dp数组的定义

根据斐波那契额数列的定义可以知dp数组的定义方式为:dp[0]=1,dp[1]=1

4.遍历顺序

根据斐波那契额数列的定义可以知dp[i]只依赖于前两个值,即dp[i-1]和dp[i-2],因此遍历顺序应是从前往后遍历。

5.打印dp数组

可通过打印dp数组进行debug。

代码实现

cpp 复制代码
class Solution {
public:
    int fib(int n) {
        if (n==0) return 0;//边界条件,若n==0,dp[1]为越界访问
        vector<int> dp(n+1);//定义dp数组
        dp[0] = 0, dp[1] = 1;//dp数组初始化
        for(int i=2; i<=n; i++)//遍历顺序
        {   dp[i] = dp[i-1] + dp[i-2]; }//递推公式
        return dp[n];
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(n)

当然可以发现,我们只需要维护两个数值就可以了,不需要记录整个序列。

cpp 复制代码
class Solution {
public:
    int fib(int N) {
        if (N <= 1) return N;
        int dp[2];
        dp[0] = 0;
        dp[1] = 1;
        for (int i = 2; i <= N; i++) {
            int sum = dp[0] + dp[1];
            dp[0] = dp[1];
            dp[1] = sum;
        }
        return dp[1];
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

动态规划常能用几个变量进行压缩使用空间。

斐波那契数列的入门性

由于斐波那契额数列的题目描述给出了递推公式和dp数组的定义方式,并且遍历顺序为即使不加以思考会自然而然想到的从前往后遍历,因此斐波那契数列为动态规划入门的简单题目,但通过这道题目也可以感受动态规划五步曲的重要性和解题步骤。

相关推荐
郝学胜-神的一滴4 分钟前
线程同步:并行世界的秩序守护者
java·linux·开发语言·c++·程序人生
im_AMBER5 分钟前
Leetcode 95 分割链表
数据结构·c++·笔记·学习·算法·leetcode·链表
明洞日记9 分钟前
【VTK手册032】vtkImageConstantPad:医学图像边界填充与尺寸对齐
c++·图像处理·vtk·图形渲染
Boilermaker199213 分钟前
[算法基础] FooldFill(DFS、BFS)
算法·深度优先·宽度优先
Aevget16 分钟前
MFC扩展库BCGControlBar Pro v37.1亮点:Ribbon Bar组件全新升级
c++·ribbon·mfc·bcg·界面控件·ui开发
leiming620 分钟前
c++ find 算法
算法
CoovallyAIHub22 分钟前
YOLOv12之后,AI在火场如何进化?2025最后一篇YOLO论文揭示:要在浓烟中看见关键,仅靠注意力还不够
深度学习·算法·计算机视觉
梭七y22 分钟前
【力扣hot100题】(121)反转链表
算法·leetcode·链表
cchjyq23 分钟前
嵌入式按键调参:简洁接口轻松调参(ADC FLASH 按键 屏幕参数显示)
c语言·c++·单片机·mcu·开源·开源软件
程序炼丹师23 分钟前
std::runtime_error是否会终止程序
c++