代码随想录 509.斐波那契数

思路:动规五部曲。

本题需要用1个一维的dp数组来保存递归的结果。

1.确定dp数组以及下标的含义:

dp[i]的定义为:第i个数的斐波那契数值是dp[i]。

2.确定递推公式:

状态转移方程 dp[i] = dp[i - 1] + dp[i - 2]

3.dp数组如何初始化:

题目中已给,dp[0] = 0,dp[1] = 1。

4.确定遍历顺序:

从递推公式dp[i] = dp[i - 1] + dp[i - 2]中可以看出,dp[i]是依赖dp[i - 1]和dp[i - 2],那么遍历顺序一定是从前往后遍历的。

5.举例推导dp数组:

按照递推公式推导一下当n为10时,dp数组应该是如下的数列。

0 1 1 2 3 5 8 13 21 34 55

如果代码写出来发现不对,就把dp数组打印出来看看和我们推导的数列是不是一致的。

附代码:

java 复制代码
class Solution {
    public int fib(int n) {
        if(n < 2) return n;
        int a = 0,b = 1,c = 0;
        for(int i = 1;i < n;i++){
            c = a + b;
            a = b;
            b = c;
        }
        return c;
    }
}
java 复制代码
//非状态压缩的版本
class Solution {
    public int fib(int n) {
        if(n <= 1) return n;
        int[] dp = new int[n + 1];
        dp[0] = 0;
        dp[1] = 1;
        for(int i = 2;i <= n;i++){
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
}
相关推荐
少许极端几秒前
算法奇妙屋(二十八)-递归、回溯与剪枝的综合问题 1
java·算法·深度优先·剪枝·回溯·递归
仰泳的熊猫2 分钟前
题目1453:蓝桥杯历届试题-翻硬币
数据结构·c++·算法·蓝桥杯
唐梓航-求职中2 分钟前
技术-算法-leetcode-1606. 找到处理最多请求的服务器(易懂版)
服务器·算法·leetcode
啊阿狸不会拉杆3 分钟前
《机器学习导论》第 10 章-线性判别式
人工智能·python·算法·机器学习·numpy·lda·线性判别式
会叫的恐龙5 分钟前
C++ 核心知识点汇总(第11日)(排序算法)
c++·算法·排序算法
twilight_4695 分钟前
机器学习与模式识别——线性回归算法
算法·机器学习·线性回归
玄同76512 分钟前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
爱吃生蚝的于勒12 分钟前
【Linux】线程概念(一)
java·linux·运维·服务器·开发语言·数据结构·vim
Pluchon15 分钟前
硅基计划4.0 算法 简单模拟实现位图&布隆过滤器
java·大数据·开发语言·数据结构·算法·哈希算法
独断万古他化20 分钟前
【算法通关】前缀和:和为 K、和被 K整除、连续数组、矩阵区域和全解
算法·前缀和·矩阵·哈希表