【代码随想录day 32】 力扣 509.斐波那契数列

视频讲解:https://www.bilibili.com/video/BV1f5411K7mo/?vd_source=a935eaede74a204ec74fd041b917810c

文档讲解:https://programmercarl.com/0509.斐波那契数.html#思路

力扣题目:https://leetcode.cn/problems/fibonacci-number/

动归五步法:

  1. 确定dpi的含义:表示第i+1个斐波那契数
  2. 确定递推公式:dpi = dpi-1 + dpi - 2;
  3. 初始化dp:dp0 = 1; int dp1 = 1;
  4. 遍历顺序:从前往后依次遍历
  5. 打印dp数组,便于调试
    可以设定一个数组来存储斐波那契数列,简单点也可以只用三个数循环更新,因为我们只需要前两个数来计算第三个数,所以设置dp0,dp1,sum,从i=2时加到i=n-1时sum就表示dpn-1,也就是第n个斐波那契数。
cpp 复制代码
class Solution {
public:
    int fib(int n) {
        //1.确定dp[i]含义:第i个斐波那契数列的数值
        //2.确定递推公式:dp[i] = dp[i-1] + dp[i - 2];
        //3.初始化dp
        int dp0 = 1;
        int dp1 = 1;
        int sum;
        if(n == 0)
        {
            return 0;
        }
        if(n == 2 || n == 1)
        {
            return 1;
        }
        //4.遍历顺序
        for(int i = 2; i < n ; ++i)
        {
            //求的是dp[i+1],n是从1到n,dp[i]是从0到i
            sum = dp0 + dp1;
            dp0 = dp1;
            dp1 = sum;
        }
        return sum;
    }
};
相关推荐
通信小呆呆5 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben0445 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..6 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅10057 小时前
【leetcode】88.合并两个有序数组js
算法
生成论实验室8 小时前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres8218 小时前
算法复键——树状数组
数据结构·算法
H178535090968 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
dayuOK63078 小时前
写作卡壳怎么办?我的“5分钟启动法”
人工智能·职场和发展·自动化·新媒体运营·媒体
不会就选b8 小时前
算法日常・每日刷题--<二分查找>3
算法