刷代码随想录有感(97):动态规划——斐波那契数列

题干:

代码:

cpp 复制代码
class Solution {
public:
    int fib(int n) {
        if(n <= 1)return n;
        vector<int> dp(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.dp数组的定义和下标。

2.递推公式(本题给出是dpi = dpi-1 + dpi-2

3.dp数组如何初始化,初始化也需要注意(本题是dp0=0 、dp1=1)

4.遍历顺序,比较考究,01 先遍历背包,后遍历物品。

4.1排列和组合的遍历顺序是不相同的。

4.1.1 排列:背包在外 物品在内。(322)

4.1.2 组合:物品在外,背包在内。(518)

5.(出现报错)打印dp数组。(打印dp数组,检查是否有问题,检验1 2 3 4 步骤)

还有,要规定dp数组的大小,如vector<int>dp(n+1),不然会报错。

相关推荐
Omics Pro42 分钟前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort1 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域1 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS2 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
小白兔奶糖ovo3 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll3 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程3 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan3 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h4 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
过期动态4 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展