[力扣题解]509. 斐波那契数

题目:509. 斐波那契数

思路

动态规划

动态规划五部曲

  1. 确定dp数组以及下标的含义
    f[i]定义为斐波拉契数列第i个数;
  2. 确定递推公式
    状态转移方程:f[i] = f[i-1] + f[i-2]
  3. dp数组如何初始化
cpp 复制代码
f[0] = 0;
f[1] = 1;
  1. 确定遍历顺序
    当前项是由前2项推理得到的,所以要从前往后遍历;
  2. 举例推导dp数组
    0 1 1 2 3 5 8 13 21 34 55

代码

cpp 复制代码
// 动态规划
class Solution {
public:
    int fib(int n) {
        int f[35] = {0};
        int i;
        f[0] = 0;
        f[1] = 1;
        for(i = 2; i <= n; i++)
        {
            f[i] = f[i-1] + f[i-2];
        }
        return f[n];
    }
};
相关推荐
童先生1 分钟前
华为云、阿里云、AWS签名机制详解! AK/SK + HMAC-SHA256 签名鉴权!
算法·阿里云·华为云·云计算
承渊政道3 分钟前
【贪心算法】(经典实战应用解析(二):最⻓递增⼦序列、递增的三元⼦序列、最⻓连续递增序列、买卖股票的最佳时机、买卖股票的最佳时机II)
数据结构·c++·学习·算法·leetcode·贪心算法·哈希算法
li星野5 分钟前
动态规划十题通关:从爬楼梯到编辑距离(Python + C++)
c++·python·学习·算法·动态规划
栈溢出了8 分钟前
GAT(Graph Attention Network)学习笔记
人工智能·深度学习·算法·机器学习
Tutankaaa8 分钟前
学校知识竞赛怎么组织?从班级到年级的进阶方案
经验分享·学习·算法·职场和发展
qcx2310 分钟前
混合检索+重排序:当前 RAG 精度提升最成熟的工程路径
算法·ai·llm·agent·rag·agentic
洛水水12 分钟前
【力扣100题】42.杨辉三角
算法·leetcode·职场和发展
東隅已逝,桑榆非晚16 分钟前
深⼊理解指针(3)
c语言·数据结构·笔记·算法·排序算法
地平线开发者19 分钟前
地平线 征程 6 工具链进阶教程 征程 6E/M 工具链 QAT 精度调优
算法·自动驾驶
小O的算法实验室2 小时前
2025年IEEE TETCI,异构无人机取送货问题中的转运优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进