[力扣题解]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];
    }
};
相关推荐
iAkuya9 分钟前
(leetcode)力扣100 18矩阵置零(哈希)
leetcode·矩阵·哈希算法
点云侠17 分钟前
粒子群优化算法求解三维变换矩阵的数学推导
线性代数·算法·矩阵
dragoooon3426 分钟前
[hot100 NO.31~36]
数据结构·算法·排序算法
白兰地空瓶26 分钟前
JavaScript 列表转树(List to Tree)详解:前端面试中如何从递归 O(n²) 优化到一次遍历 O(n)
javascript·算法·面试
艾醒28 分钟前
大模型原理剖析——从技术特性、底层架构到落地逻辑的全维度解析
算法
Liangwei Lin40 分钟前
洛谷 B3637 最长上升子序列
算法
珂朵莉MM1 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第一赛季优化题--无人机配送
人工智能·算法·无人机
xiaoxue..1 小时前
列表转树结构:从扁平列表到层级森林
前端·javascript·算法·面试
代码游侠1 小时前
复习——线程(pthread)
linux·运维·开发语言·网络·学习·算法
papaofdoudou1 小时前
基于QEMU 模拟intel-iommu的sva/svm demo环境搭建和验证
算法·机器学习·支持向量机