[力扣题解]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];
    }
};
相关推荐
秋夫人10 分钟前
B+树(B+TREE)索引
数据结构·算法
梦想科研社1 小时前
【无人机设计与控制】四旋翼无人机俯仰姿态保持模糊PID控制(带说明报告)
开发语言·算法·数学建模·matlab·无人机
Milo_K1 小时前
今日 leetCode 15.三数之和
算法·leetcode
Darling_001 小时前
LeetCode_sql_day28(1767.寻找没有被执行的任务对)
sql·算法·leetcode
AlexMercer10121 小时前
【C++】二、数据类型 (同C)
c语言·开发语言·数据结构·c++·笔记·算法
Greyplayground1 小时前
【算法基础实验】图论-BellmanFord最短路径
算法·图论·最短路径
蓑 羽1 小时前
力扣438 找到字符串中所有字母异位词 Java版本
java·算法·leetcode
源代码:趴菜1 小时前
LeetCode63:不同路径II
算法·leetcode·职场和发展
儿创社ErChaungClub1 小时前
解锁编程新境界:GitHub Copilot 让效率翻倍
人工智能·算法
前端西瓜哥1 小时前
贝塞尔曲线算法:求贝塞尔曲线和直线的交点
前端·算法