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

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

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

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

动归五步法:

  1. 确定dp[i]的含义:表示第i+1个斐波那契数
  2. 确定递推公式:dp[i] = dp[i-1] + dp[i - 2];
  3. 初始化dp:dp0 = 1; int dp1 = 1;
  4. 遍历顺序:从前往后依次遍历
  5. 打印dp数组,便于调试
    可以设定一个数组来存储斐波那契数列,简单点也可以只用三个数循环更新,因为我们只需要前两个数来计算第三个数,所以设置dp0,dp1,sum,从i=2时加到i=n-1时sum就表示dp[n-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;
    }
};
相关推荐
橘颂TA几秒前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
苦藤新鸡3 分钟前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
猫头虎8 分钟前
2026年1月18日11时博客之星投票数据TOP100总排名预测:全网投票总数突破一万大关
程序人生·职场和发展·创业创新·业界资讯·程序员创富·csdn·博客之星
程序员-King.13 分钟前
day145—递归—二叉树的右视图(LeetCode-199)
算法·leetcode·二叉树·递归
漫随流水17 分钟前
leetcode算法(112.路径总和)
数据结构·算法·leetcode·二叉树
过期的秋刀鱼!24 分钟前
机器学习-带正则化的成本函数-
人工智能·python·深度学习·算法·机器学习·逻辑回归
ScilogyHunter26 分钟前
前馈/反馈控制是什么
算法·控制
oscar99929 分钟前
软件测试面试全攻略之高级篇
面试·职场和发展·测试高级
_OP_CHEN37 分钟前
【算法基础篇】(四十八)突破 IO 与数值极限:快速读写 +__int128 实战指南
c++·算法·蓝桥杯·算法竞赛·快速读写·高精度算法·acm/icpc
程序员泠零澪回家种桔子41 分钟前
RAG自查询:让AI精准检索的秘密武器
人工智能·后端·算法