代码随想录打卡—day38—【DP】— 8.24 DP基础

1 DP理论基础

1.1 什么是DP

如果某一问题有很多重叠子问题,使用动态规划是最有效的。

动规是由前一个状态推导出来的,而贪心是局部直接选最优的。

1.2 DP解题步骤

  1. 确定dp数组(dp table)以及下标的含义
  2. 确定状态转移公式 / 递推公式
  3. dp数组如何初始化
  4. 确定遍历顺序
  5. 举例推导dp数组

1.3 动态规划应该如何debug

找问题的最好方式就是把dp数组打印出来,看看究竟是不是按照自己思路推导的!

做动规的题目,写代码之前一定要把状态转移在dp数组的上具体情况模拟一遍,心中有数,确定最后推出的是想要的结果 。然后再写代码,如果代码没通过就打印dp数组,看看是不是和自己预先推导的哪里不一样。如果打印出来和自己预先模拟推导是一样的,那么就是自己的递归公式、初始化或者遍历顺序有问题了。如果和自己预先模拟推导的不一样,那么就是代码实现细节有问题。这样才是一个完整的思考过程,而不是一旦代码出问题,就毫无头绪的东改改西改改,最后过不了,或者说是稀里糊涂的过了

2 509. 斐波那契数

通过一个简单题,讲一下dp套路,AC代码:

cpp 复制代码
class Solution {
public:
    int dp[40];  // step1:确定状态数组和含义

    int fib(int n) 
    {
        dp[0] = 0;  // step3: 初始化
        dp[1] = 1;
        for(int i = 2; i <= n;i++)  // step4:确定遍历顺序
            dp[i] = dp[i-1]+dp[i-2];  // step2:确定转移函数
        return dp[n];
    }
};

3 70. 爬楼梯

70. 爬楼梯

一次做,AC代码:

疑问:怎么判断用搜索还是dp?这题,我没有受过dp训练所以第一反应是用dfs搜索,找到所有符合要求的叶子。

cpp 复制代码
class Solution {
public:
    int dp[50];    // step1:含义: 对于下标i  有多少种方案到第i层
    /*
    step2:状态转移方程 dp[i] = dp[i-2] + dp[i-1]
    step3: dp数组初始化 dp[1] = 1 , dp[2] = 2
    step4: 遍历顺序 i递增
    step5: 模拟 1,2,3(1 1 1 + 2 1 +1 2 ),5
    */ 
    int climbStairs(int n) 
    {
        // 这题我的第一感觉是搜索 什么时候用dp????
        dp[1] = 1;
        dp[2] = 2;
        for(int i = 3; i <= n; i++)
            dp[i] = dp[i-1] + dp[i-2];
        return dp[n];
    }
};

4 746. 使用最小花费爬楼梯

746. 使用最小花费爬楼梯

写简单dp题好有意思md可能是太简单,一次ac:

cpp 复制代码
class Solution {
public:
    int dp[1010]; // 第i --- 表示到达i层的最小花费
    /*
    dp[i] = min(dp[i-2]+cost[i-2],dp[i-1]+cost[i-1])
    dp[0] = 0;
    dp[1] = 0;
    增序
    模拟dp  0 0 10 15
    */
    int minCostClimbingStairs(vector<int>& cost) 
    {
        dp[0] = 0;
        dp[1] = 0;
        int i = 2;
        for(; i < cost.size();i++)
            dp[i] = min(dp[i-2]+cost[i-2],dp[i-1]+cost[i-1]);
        return min(dp[i-2]+cost[i-2],dp[i-1]+cost[i-1]);
    }
};
相关推荐
CoovallyAIHub9 分钟前
单目深度估计重大突破:无需标签,精度超越 SOTA!西湖大学团队提出多教师蒸馏新方案
深度学习·算法·计算机视觉
CoovallyAIHub12 分钟前
从FCOS3D到PGD:看深度估计如何快速搭建你的3D检测项目
深度学习·算法·计算机视觉
偷偷的卷40 分钟前
【算法笔记 day three】滑动窗口(其他类型)
数据结构·笔记·python·学习·算法·leetcode
北京地铁1号线1 小时前
Zero-Shot(零样本学习),One-Shot(单样本学习),Few-Shot(少样本学习)概述
人工智能·算法·大模型
凤年徐1 小时前
【数据结构】时间复杂度和空间复杂度
c语言·数据结构·c++·笔记·算法
kualcal1 小时前
代码随想录17|二叉树的层序遍历|翻转二叉树|对称二叉树
数据结构·算法
满分观察网友z2 小时前
从混乱到有序:我用“逐层扫描”法优雅搞定公司组织架构图(515. 在每个树行中找最大值)
后端·算法
满分观察网友z2 小时前
一行代码的惊人魔力:从小白到大神,我用递归思想解决了TB级数据难题(3304. 找出第 K 个字符 I)
后端·算法
字节卷动2 小时前
【牛客刷题】活动安排
java·算法·牛客
yi.Ist3 小时前
数据结构 —— 键值对 map
数据结构·算法