DAY41:动态规划(一)动态规划理论基础

news2024/7/6 18:34:32

文章目录

    • DP概念以及和贪心的区别
    • 动规问题分类
      • 基础问题
      • 背包问题
      • 打家劫舍
      • 股票问题
      • 子序列问题
    • DP注意点
    • 解题步骤:五步
        • debug考虑方向

视频课程:从此再也不怕动态规划了,动态规划解题方法论大曝光 !| 理论基础 |力扣刷题总结| 动态规划入门_哔哩哔哩_bilibili

DP概念以及和贪心的区别

动态规划,英文:Dynamic Programming,简称DP,如果某一问题有很多重叠子问题,使用动态规划是最有效的。

所以动态规划中每一个状态一定是由上一个状态推导出来的这一点就区分于贪心,贪心没有状态推导,而是从局部直接选最优的。

例如:有N件物品和一个最多能背重量为W 的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品只能用一次,求解将哪些物品装入背包里物品价值总和最大。

动态规划中dp[j]是由dp[j-weight[i]]推导出来的,然后取max(dp[j], dp[j - weight[i]] + value[i])

但如果是贪心,就是每次拿物品选一个最大的或者最小的就结束,和上一个状态没有关系

所以贪心解决不了动态规划的问题。

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

动规问题分类

基础问题

包括斐波那契数列、爬楼梯等动规基础问题

背包问题

是动规的经典系列,也是大厂面试很喜欢考察的类型。

打家劫舍

打家劫舍系列在力扣上一共三道题,最后一道是树形dp,也是比较经典的问题。

股票问题

类似今天买哪天卖可以获得最大利润,这个系列7-8题,也是较为经典的问题

子序列问题

子序列问题一般都是求最长递增子序列/最长连续递增子序列,以及非常经典的编辑问题(给两个字符串,问使得两个字符串相等的最小编辑数)

区间dp,概率dp主要是竞赛拔尖题目,过于难的动态规划一般面试不会考

DP注意点

看题解的时候不能过度注重递推公式,递推公式只是一部分,状态转移公式(递推公式)是很重要,但动规不仅仅只有递推公式

解题步骤:五步

  1. 状态转移的时候都会定义dp数组,需要知道dp数组的含义下标的含义。例如求子序列问题,一般dp数组就是二维的,背包问题有时候也是二维的,此时我们就需要知道i和j分别是什么意思。

​ 同理,一维dp数组里面的数值和下标分别的含义,也都要搞清楚。

  1. 递推公式:递推公式很重要,但是并不是动态规划所有的部分。

  2. DP数组如何初始化:这一点需要首先想清楚DP数组下标和数值的含义。有的时候数组初始化成0,但是有的时候需要初始化成1,有的是i=1/i=2往后初始成0,往前初始成1。这些情况都有可能。

    (例如力扣题目:不同路径,在初始化的地方有坑,初始化是需要注意的)一些情况是递推公式决定了dp数组要如何初始化

  3. DP数组遍历顺序背包类的题目对遍历顺序很有讲究,例如01背包里面两个for循环,应该先遍历物品还是先遍历背包?遍历顺序从前到后/从后到前?

    完全背包问题,求排列和求组合,遍历顺序是完全不同的。

    背包问题的遍历顺序含义如下图所示:

在这里插入图片描述
在背包问题里,递推公式的类型其实很固定,关键就在遍历顺序上。大厂的算法题考察很可能是先给一道比较简单的题目,再一点一点变化,难度就会递增。背包问题可能出的变化就会在遍历顺序上,到时候可以进行一些衍生问题的整理。

  1. 打印DP数组:DP类题目出问题很难直接通过代码看出来,需要直接打印DP数组,根据DP数组的含义和下标含义,看看逻辑是不是对的上。如果题目一直通过不了,打印出来的DP数组一定是有问题的,根据打印结果倒推递推公式和遍历顺序的问题。

debug考虑方向

  • 题目举例推导状态转移公式?
  • 打印dp数组的日志?
  • 打印出来了dp数组和自己想的是否一样?

状态转移和遍历顺序/数组数值及下标含义都很重要。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/730108.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

3.1.cuda运行API-概述

目录 前言1. Runtime API概述总结 前言 杜老师推出的 tensorRT从零起步高性能部署 课程,之前有看过一遍,但是没有做笔记,很多东西也忘了。这次重新撸一遍,顺便记记笔记。 本次课程学习精简 CUDA 教程-Runtime API 概述 课程大纲可…

MachineLearningWu_3_LinearRegression

3 Linear Regression Linear Regression即是根据数据做出预测,如下, training set 如下: 在Linear Regression中你可以将(x, y)看做如下,每一行是一个sample,而每一列除最后一列是一个feature&#xff0c…

ESP32(掌控板) RGB灯控制

ESP32(掌控板) RGB灯控制 本程序实现了RGB灯亮度和颜色调节,通过触摸按键分别调节RGB值,通过机械按键选择要调节的灯或使用预设均通过调整变量的值加上判断实现。预设包含随机颜色和流水灯,各有高亮度和低亮度两种版本…

《Kali渗透基础》07. 弱点扫描(一)

kali渗透 1:漏洞发现1.1:Exploit-DB1.2:searchsploit1.3:nmap 2:漏洞管理3:弱点扫描类型4:漏洞基本概念4.1:CVSS4.2:CVE4.3:OVAL4.4:CCE4.5&#…

TCP概念

文章目录 1.TCP1.1 为什么需要 TCP 协议?TCP 工作在哪一层?1.2 什么是 TCP ?1.3 什么是 TCP 连接?1.4 如何唯一确定一个 TCP 连接?1.5 有一个 IP 的服务器监听了一个端口,它的 TCP 的最大连接数是多少&…

nginx的权限问题(13: Permission denied)解决办法

1、查看nginx启动用户和使用用户是否一致 ps aux | grep nginx 如图: 一个是www,一个是root用户 2、打开nginx配置文件 打开 nginx.conf 文件 查找nginx.conf的位置 ps -aux | grep nginx 3、把 nginx 改为 root 4、重启nginx服务 service nginx restart …

性能监控平台 | Prometheus+InfluxDB + Grafana!

在本文中,我将把几个常用的监控部分给梳理一下。前面我们提到过,在性能监控图谱中,有操作系统、应用服务器、中间件、队列、缓存、数据库、网络、前端、负载均衡、Web 服务器、存储、代码等很多需要监控的点。显然这些监控点不能在一个专栏中…

USG6000V 防火墙的策略应用

将G1/0/0划入TRUST区 firewall zone trustadd interface GigabitEthernet1/0/0 将G1/0/1划入UNTRUST区 firewall zone untrustadd interface GigabitEthernet1/0/1在防火墙上配置放行策略 security-policyrule name 1source-zone trustdestination-zone localdestination-z…

2023年船舶、海洋与海事工程国际会议(NAOME 2023) | Ei Scopus双检索

会议简介 Brief Introduction 2023年船舶、海洋与海事工程国际会议(NAOME 2023) 会议时间:2023年10月20日-22日 召开地点:中国镇江 大会官网:NAOME 2023-2023 International Conference on Naval Architecture and Ocean & Marine Engine…

Yolov8方法笔记

目录 1、安装yolov8的虚拟环境 (1)创建虚拟环境 (2)安装pytorch ​编辑 2、下载yolov8模型 3、解压缩,解压后的文件 4、将转换数据集(以口罩检测为准) 5、配置和执行 6、验证 7、测试 1、…

14-C++基本算法-深度优先搜索

&#x1f4da; 从递归阶乘到深度优先搜索 在学习深度优先搜索之前&#xff0c;我们先回顾一下递归阶乘的实现。递归阶乘是一种典型的递归算法&#xff0c;它通过将问题分解为更小的子问题来解决。 #include <iostream> using namespace std;int factorial(int n) {if (…

【PCIE】协议分析之-hot-reset热复位

被上游指定热复位整个通路 当高层&#xff08;higher Layer&#xff09;指示某些通道进行热复位&#xff08;Hot Reset&#xff09;时&#xff0c;以下操作将被执行&#xff1a; 所有在配置的链路中的通道都会发送带有热复位位&#xff08;Hot Reset bit&#xff09;和配置的…

IntelliJ IDEA运行bat脚本,自动taskkill端口进程

在idea运行完程序后&#xff0c;再次重新运行时如果之前的程序仍然占用着端口会导致报错&#xff1a;端口被占用。 因此每次重新运行都需要移除之前的端口所在的进程&#xff0c;这对于调试开发过程是非常频繁的操作。 需要一个快速的办法直接移除端口进程&#xff0c;如下&a…

Haskell 入门学习(一)之安装试用 Haskell

Haskell 入门学习&#xff08;一&#xff09;之安装试用 Haskell 文章目录 Haskell 入门学习&#xff08;一&#xff09;之安装试用 Haskell前言&#xff1a;安装Windows 安装Linux、MacOs 使用 VSCode 进行代码编写创建一个简单的项目使用 Cabal 管理项目项目大致结构运行项目…

Verilog学习笔记3:与非门

1位的与非门 代码&#xff1a; timescale 1ns/10ps module nand_gate( A, B, Y);input A; input B; output Y;assign Y~(A&B);endmodule//testbenchmodule nand_gate_tb; reg A; reg B; wire Y;nand_gate nand_gate(.A(A),.B(B),.Y(Y));initial begin A<0;B<0;#10 …

Ubuntu创建Git项目并push到远程Github

首先在本地创建git仓库 jasminelhl:~/prj$ mkdir Github-test jasminelhl:~/prj$ cd Github-test jasminelhl:~/prj/Github-test$ git init 提示&#xff1a;使用 master 作为初始分支的名称。这个默认分支名称可能会更改。要在新仓库中 提示&#xff1a;配置使用初始分支名&a…

MySQL之CONCAT、CONCAT_WS和GROUP_CONCAT函数用法

目录 一、准备数据 二、concat函数 1.语法格式 2.语法说明 3.场景使用 4.限制条件 三、concat_ws函数 1.语法格式 2.语法说明 3.场景使用 4.限制条件 四、group_conat函数 1.语法格式 2.语法说明 3.场景使用 4.限制条件 一、准备数据 #创建用户表 CREATE TABL…

[已解决]Springboot项目启动时端口被占用

目录 1.打开CMD窗口 2.找到端口号 3.找到对应程序 4.终止任务 5.再次查询端口&#xff0c;没有找到对应的端口号说明进行杀死成功 6. 重新启动项目&#xff0c;可以正常启动 Springboot端口号默认8080&#xff0c;启动时经常会遇到端口号被占用的情况&#xff0c;报错信息…

swift 打包xcframework报错“No ‘swiftinterface‘ files found within“

1、分别编译当前的framework&#xff0c;生成对应的真机framework与模拟器framework 生成对应framework.png 2、新建一个对应接收xcframework的文件夹&#xff0c;以XXX.xcframework格式命名 3、打开终端利用xcodebuild -create-xcframework命令进行生成xcframework。 具体如…

第一章 计算机网络概述【计算机网络】

第一章 计算机网络概述【计算机网络】 前言推荐第一章 计算机网络概述1.1 计算机网络在信息时代中的作用1.2互联网概述1.2.1 网络的网络1.2.2互联网基础结构发展的三个阶段1.2.3互联网的标准化工作 1.3互联网的组成1.3.1互联网的边缘部分1.3.2互联网的核心部分 1.4计算机网络在…