当前位置: 首页 > news >正文

leetcode重点题目分类别记录(三)动态规划深入与素数理论

文章目录

  • 动态规划
    • 背包问题
      • 01背包
        • 抽象出求解目标
        • 尝试进程子问题拆分
        • 基本情况
        • 根据拆分过程定义dp数组与转移方程
        • 遍历顺序与状态压缩
        • 模板归纳
        • 题目应用
        • 变种提升
          • 组合问题
          • 多维01背包
          • 有特殊限制的01背包
      • 完全背包
    • 打家劫舍
    • 股票系列
    • 子序列类
    • 数位dp

动态规划

背包问题

01背包

有C0-Cx件物品,每个物品价值对应为V0-Vx,有容量为N的背包,问背包能够装的最大价值。

由于每件物品只有装与不装两个状态,因此称为01背包。

抽象出求解目标

目标:C0-Cx可选,价值V0-Vx,容量为N能够装下的最大值。

尝试进程子问题拆分

子问题拆分:
假设:Cx物品选了,那么问题缩减为求解:
C0-Cx-1可选,价值V0 - Vx-1,容量为N-Vx,能够装下的最大值。
假设:Cx物品不选,那么问题缩减为求解:
C0-Cx-1可选,价值V0 - Vx-1,容量为N,能够装下的最大值。

基本情况

很显然,每件物品我们都可以按照上边的想法进行拆分求解。
当容量为0,价值为0。

根据拆分过程定义dp数组与转移方程

定义:dp[i][j]为物品0-i任意取,放进容量为j的背包中能够装的最大重量。

转移方程:dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - value[i]]);

遍历顺序与状态压缩

dp[i][j]依赖它的上边和左上边的数据结果,因此,遍历顺序自上而下,自左而右。

滚动数组:由于每个数据只依赖上一行两个数据的结果,因此可以使用滚动数组来更新dp数组,由于需要的是左上方的数据和上方的数据,因此,对于背包容量我们逆序遍历时,遍历到某个位置时,此时的滚动数组就保留了左上和上的结果;
即dp[j] = max(d[j], dp[j - value[i]]);

模板归纳

枚举每个物品,逆序遍历背包,递推公式为dp[j] = max(d[j], dp[j - value[i]]);

题目应用

在这里插入图片描述
子集就是每个元素选或不选,最后构成的一种组合。计算数组的总和为sum,如果给定背包容量为sum / 2 能够装满,那么就存在,否则不存在。

 bool canPartition(vector<int>& nums) {int sum = accumulate(nums.begin(), nums.end(), 0);if (sum & 1) return false; // 如果sum为奇数,必不可等分int target = sum >> 1; // 最终要找的组合,它的累计和是nums累计和的一半。vector<int> dp(target + 1, 0);for (int num : nums) {for (int j = target; j >= num; --j) dp[j] = max(dp[j], dp[j - num] + num);}return dp[target] == target;
}

变种提升

组合问题

01背包还可以用于计算装满容量为N的物品的组合数。
在这里插入图片描述
n个数,每个数可以是正负两种状态,不过这里要求的是组合数。

首先,由于符号未定,我们的物品是不确定的。
但是元素总和是确定的sum,
假设加法总和为x,所有元素总和为sum,那么减法元素总和为sum - x。
target = x - (sum - x) = 2x - sum
x = (sum + target) / 2

sum和target都是已知的。

因此也就是,问题可以转为装满容量为x的背包的方法数。
这样就只用考虑正数。

设dp[i][j]表示0-i元素任意选,装满j的方法数:
假设i选择:
dp[i][j] = dp[i - 1][j - nums[i]]
假设i不选:
dp[i][j] = dp[i - 1][j]

总方法数:
dp[i][j] = dp[i - 1][j - nums[i]] + dp[i - 1][j]

状态转移方程与01背包几乎一致,考虑滚动数组压缩:
dp[j] = dp[j - nums[i]] + dp[j]
进一步:
dp[j] += dp[j - nums[i]]

此外注意:求方法数时,容量为0,方法数为1,即都不选!!!。

    int findTargetSumWays(vector<int>& nums, int target) {int sum = accumulate(nums.begin(), nums.end(), 0);if (abs(target) > sum) return 0;if ((target + sum) % 2) return 0;int bagSize = (target + sum) >> 1;vector<int> dp(bagSize + 1);dp[0] = 1;for (int num : nums) {for (int j = bagSize; j >= num; --j) {dp[j] += dp[j - num];}} }return dp[bagSize];
多维01背包

在这里插入图片描述
同样是子集问题,每个元素选或者不选两种情况,所不同的时,有0和1两方面的限制,即背包容量的维度是2维的。

dp[i][j][k]表示0-i物品任意选,0的容量为j,1的容量为k,能够装的物品数。
子情况拆分:
第i个选品如果选:假设第i个物品0的个数为cnt0i、1的个数为cnt1i。
dp[i][j][k] = dp[i - 1][j - cnt0i][cnt1i] + 1;
第i个物品如果不选:
dp[i][j][k] = dp[i][j][k];

转移方程和01背包一致,只依赖上方和左上方,可以逆序遍历背包容量来做成滚动数组形式;

int findMaxForm(vector<string>& strs, int m, int n) {vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0));for (const string &str : strs) {int cntOne = 0;for (char c : str) cntOne += c - '0';int cntZero = str.size() - cntOne;for (int i = m; i >= cntZero; --i) {for (int j = n; j >= cntOne; --j) {dp[i][j] = max(dp[i][j], dp[i - cntZero][j - cntOne] + 1);}}}return dp[m][n];
}
有特殊限制的01背包

在这里插入图片描述
在这里插入图片描述

这道题也是0、1背包,但是物品有主件和附件之分,每个主件可以有0,1或者2个附件,附件必须依赖主件。

有主附之分的物品是无法直接应用01背包模板的,我们需要把元素进行组装。

具体而言,一个元素的价格有四种可能,主件,主件+附件1,主件+附件2,主件+附件1+附件2。

相应的,也需要把物品的价值(即满意度进行组装)

注意点:
1、从示例2可以看出,行号为物品编号,附件可以出现在主件前,因此先用prices和values先把数据保存下来。
2、主件价格为0可以直接跳过
3、遍历每个主件时,将它与附件进行组合:主件,主件+附件1,主件+附件2,主件+附件1+附件2。
4、应用背包模板,逆序遍历背包容量。
5、输入都除10,可以降低时空复杂度,但需要注意后边输出时乘回来。

#include <bits/stdc++.h>
#include <vector>
using namespace std;int main() {int N, m;cin >> N >> m;N /= 10;vector<vector<int>> prices(m + 1, vector<int> (4)), values (m + 1, vector<int> (4));// prices[i]:3个元素,分别为i号主件价格,i号主件的附件1价格,i号主件的附件2价格for (int i = 1; i <= m; ++i) {int v, p, q;cin >> v >> p >> q;v /= 10;p *= v;if (q == 0) {// 0 : 主件prices[i][0] = v;values[i][0] = p;} else {if (prices[q][1] == 0) {// 1 : 附件1prices[q][1] = v;values[q][1] = p;} else {// 2 : 附件2prices[q][2] = v;values[q][2] = p;}}}vector<int> dp(N + 1);for (int i = 1; i <= m; ++i) {if (prices[i][0] == 0) continue;int p1 = prices[i][0], p2 = p1 + prices[i][1], p3 = p1 + prices[i][2], p4 = p2 + p3 - p1;int v1 = values[i][0], v2 = v1 + values[i][1], v3 = v1 + values[i][2], v4 = v2 + v3 - v1; for (int j = N; j >= p1; --j) {dp[j] = j >= p1 ? max(dp[j], dp[j - p1] + v1) : dp[j];dp[j] = j >= p2 ? max(dp[j], dp[j - p2] + v2) : dp[j];dp[j] = j >= p3 ? max(dp[j], dp[j - p3] + v3) : dp[j];dp[j] = j >= p4 ? max(dp[j], dp[j - p4] + v4) : dp[j];}}cout << dp[N] * 10 << endl;return 0;
}

完全背包

打家劫舍

股票系列

子序列类

数位dp

相关文章:

leetcode重点题目分类别记录(三)动态规划深入与素数理论

文章目录动态规划背包问题01背包抽象出求解目标尝试进程子问题拆分基本情况根据拆分过程定义dp数组与转移方程遍历顺序与状态压缩模板归纳题目应用变种提升组合问题多维01背包有特殊限制的01背包完全背包打家劫舍股票系列子序列类数位dp动态规划 背包问题 01背包 有C0-Cx件物…...

面试篇-学习Java多线程编程必备:深入理解volatile与synchronized

1. 概述 1.1 Volatile概述 Volatile是Java中的一种轻量级同步机制&#xff0c;用于保证变量的可见性和禁止指令重排。当一个变量被声明为Volatile类型时&#xff0c;任何修改该变量的操作都会立即被所有线程看到。也就是说&#xff0c;Volatile修饰的变量在每次修改时都会强制…...

后端系列文章

后端系列文章目录 缘由&#xff1a;无聊了&#xff0c;写点博客玩玩 注&#xff1a;该系列文章纯属个人见解&#xff0c;漏洞百出&#xff0c;大家看个乐就行了&#xff0c;别当真&#xff01; 私人博客 许小墨のBlog —— 菜鸡博客直通车 系列文章完整版&#xff0c;配图更多&…...

C++之AVL树

文章目录前言一、概念二、AVL树结点的定义三、AVL树的插入四、AVL树的旋转1.右单旋的情况以及具体操作抽象图h 0h 1h 2代码实现2.左单旋的情况以及具体操作抽象图代码实现3.右左双旋的情况以及具体操作抽象图h 0h 1h 23.左右双旋的情况以及具体操作抽象图5.总结6.完整实现…...

【ROS2指南-2】入门 turtlesim 和 rqt

目标&#xff1a;安装并使用 turtlesim 包和 rqt 工具为即将到来的教程做准备。 教程级别&#xff1a;初学者 时间&#xff1a; 15分钟 内容 背景 先决条件 任务 1 安装turtlesim 2 启动turtlesim 3 使用turtlesim 4 安装rqt 5 使用 rqt 6 重新映射 7 关闭turtlesim …...

Python 进阶指南(编程轻松进阶):四、起个好名字

原文&#xff1a;http://inventwithpython.com/beyond/chapter4.html 计算机科学中最困难的两个问题是命名事物、缓存失效引起错误."这个经典的笑话&#xff0c;出自利昂班布里克之手&#xff0c;并基于菲尔卡尔顿的一句话&#xff0c;包含了一个真理的核心&#xff1a;很…...

STL容器适配器之<priority_queue>

文章目录测试环境priority_queue介绍头文件模块类定义对象构造元素访问元素插入和删除容器大小迭代器其他函数测试环境 系统&#xff1a;ubuntu 22.04.2 LTS 64位 gcc版本&#xff1a;11.3.0 编辑器&#xff1a;vsCode 1.76.2 priority_queue介绍 容器适配器。支持在末端插入…...

线程——线程同步

案例&#xff1a;卖票 需求&#xff1a;某电影院目前正在上映国产大片&#xff0c;共有100张票&#xff0c;而它有三个窗口卖票&#xff0c;请设计一个程序模拟该电影院卖票 思路&#xff1a; 定义一个类SellTicket实现Runnable接口&#xff0c;里面定义一个成员变量&#xff…...

安卓录屏使用VirtualDisplay虚拟屏幕;MediaRecorder,媒体录影机;

1.跟截屏一样&#xff0c;判断权限&#xff0c;然后在onActivityResult里面给mediaProjection赋能&#xff1b; 2.初始化录像机&#xff1a; //初始化Recorder录像机 fun initRecorderStart() { //新建Recorder val displayMetrics DisplayMetrics() val width displayMetri…...

Java FileChannel文件的读写实例

一、概述&#xff1a; 文件通道FileChannel是用于读取&#xff0c;写入&#xff0c;文件的通道。FileChannel只能被InputStream、OutputStream、RandomAccessFile创建。使用fileChannel.transferTo()可以极大的提高文件的复制效率&#xff0c;他们读和写直接建立了通道&#x…...

2023 年男生还推荐报计算机专业吗?

计算机专业确实是一个非常热门的专业&#xff0c;就业前景也很广阔。 但是&#xff0c;近些年随着各个大学对计算机专业及其相关专业疯狂扩招&#xff0c;而且每年的毕业人口都在增多&#xff0c;行业是根本容纳不下的&#xff0c;就业竞争力度也急剧上升。因此&#xff0c;选…...

【华为OD机试真题】积木最远距离(相同数字的积木游戏1)(javapython)

相同数字的积木游戏1 知识点数组循环map 时间限制:1s 空间限制:256MB 限制语言:不限 题目描述: 小华和小薇一起通过玩积木游戏学习数学。 他们有很多积木,每个积木块上都有一个数字,积木块上的数字可能相同。 小华随机拿一些积木挨着排成一排,请小薇找到这排积木中数…...

STM32F103RCT6驱动SG90舵机-完成正反转角度控制

一、SG90舵机介绍 SG90是一种微型舵机&#xff0c;也被称为伺服电机。它是一种小型、低成本的直流电机&#xff0c;通常用于模型和机器人控制等应用中。SG90舵机可以通过电子信号来控制其精确的位置和速度。它具有体积小、重量轻、响应快等特点&#xff0c;因此在各种小型机械…...

【4.13(补)】二叉搜索树的遍历、插入、删除

文章目录二叉搜索树的最近公共祖先二叉搜索树中的插入操作删除二叉搜索树中的节点二叉搜索树的最近公共祖先 235. 二叉搜索树的最近公共祖先 - 力扣&#xff08;LeetCode&#xff09; 因为二叉搜索树是有序的&#xff0c;第一次找到p和q中间的值&#xff0c;就是最近的公共祖先…...

Web 攻防之业务安全:Callback自定义测试(触发XSS漏洞)

Web 攻防之业务安全&#xff1a;Callback自定义测试 业务安全是指保护业务系统免受安全威胁的措施或手段。广义的业务安全应包括业务运行的软硬件平台&#xff08;操作系统、数据库&#xff0c;中间件等&#xff09;、业务系统自身&#xff08;软件或设备&#xff09;、业务所提…...

Java访问底层操作系统

native方法定义&#xff1a; 简单地讲&#xff0c;一个Native Method就是一个java调用非java代码的接口。一个Native Method是这样一个java的方法&#xff1a;该方法的实现由非java语言实现&#xff0c;比如C。这个特征并非java所特有&#xff0c;很多其它的编程语言都有这一机…...

Python 进阶指南(编程轻松进阶):十六、面向对象编程和继承

原文&#xff1a;http://inventwithpython.com/beyond/chapter16.html 定义一个函数&#xff0c;并从几个地方调用它&#xff0c;可以省去复制和粘贴源代码的麻烦。不复制代码是一个很好的实践&#xff0c;因为如果你需要修改它&#xff08;无论是为了修复一个错误还是添加新特…...

【计算机系统结构】第一章 计算机系统结构基本概念

文章目录第一章 计算机系统结构基本概念1.1 计算机系统结构的概念1.2 计算机体系结构的发展1.3 系统结构中并行性的发展1.4 系统结构的设计1.5 定量分析技术基础第一章 计算机系统结构基本概念 课程内容 A I P S N 工业革命 1.1 计算机系统结构的概念 引言 第一台通用计算机 …...

e2fsprogs logsave Ubuntu 安装失败 unable to make backup link of ‘./usr/bin/chattr‘

最近给服务器从 Ubuntu 18.04 LTS 升级到 20.04 LTS&#xff0c;过程中崩溃&#xff0c;重新尝试执行&#xff0c;提示依赖错误。这时候 apt install 所有的东西都会报错&#xff0c;提示依赖不满足。&#xff08;这里的报错忘了复制了&#xff09;执行 apt upgrade 也是一样。…...

在排序数组中查找元素的第一个和最后一个位置(二分查找进阶)

在写这个题目之前需要大家自行看一下我之前写的博客有关二分查找思想,如何判断什么时候使用二分查找以及边界值的确定:二分查找思想力扣实例_徐憨憨&#xff01;的博客-CSDN博客 题目:给你一个按照非递减顺序排列的整数数组 nums&#xff0c;和一个目标值 target。请你找出给定…...

别再只用高斯噪声了!手把手教你为DDPG算法注入‘惯性’:Ornstein-Uhlenbeck噪声的Python实现与调参实战

突破DDPG探索瓶颈&#xff1a;Ornstein-Uhlenbeck噪声的工程实践指南 在机器人控制或自动驾驶仿真这类连续动作空间的任务中&#xff0c;DDPG算法常因探索效率低下导致训练停滞。当智能体在MuJoCo环境中反复"原地踏步"时&#xff0c;问题往往不在于算法本身&#xf…...

HS2-HF Patch:3步安装HoneySelect2终极增强补丁完整指南

HS2-HF Patch&#xff1a;3步安装HoneySelect2终极增强补丁完整指南 【免费下载链接】HS2-HF_Patch Automatically translate, uncensor and update HoneySelect2! 项目地址: https://gitcode.com/gh_mirrors/hs/HS2-HF_Patch HS2-HF Patch是HoneySelect2玩家的游戏增强…...

从零实现神经网络:前向传播、反向传播与梯度下降原理详解

1. 项目概述&#xff1a;从“黑箱”到“白箱”的探索之旅“人工神经网络”这个词&#xff0c;听起来总带着点科幻和神秘色彩&#xff0c;仿佛一个能自己思考的“黑箱”。很多刚接触的朋友&#xff0c;包括几年前的我&#xff0c;都曾被它吓住——又是矩阵运算&#xff0c;又是梯…...

航空发电机综合测试系统设计【附代码】

✨ 长期致力于航空发电机、测试系统、控制方法、LabVIEW研究工作&#xff0c;擅长数据搜集与处理、建模仿真、程序编写、仿真设计。 ✅ 专业定制毕设、代码 ✅ 如需沟通交流&#xff0c;点击《获取方式》 &#xff08;1&#xff09;设计直流拖动调速系统的双闭环自适应模糊PID控…...

Zabbix监控大屏展示中文总乱码?手把手教你替换DejaVuSans为微软雅黑字体

Zabbix监控大屏中文乱码终极解决方案&#xff1a;从字体替换到视觉优化 当你精心配置的Zabbix监控大屏在向管理层汇报时突然出现中文乱码&#xff0c;那种尴尬就像交响乐团演出时小提琴突然走音。作为经历过数十次企业级监控系统部署的资深运维&#xff0c;我深知字体问题远不止…...

仅0.3%用户掌握的胶片叙事技巧:用Midjourney实现“过期胶卷”时间衰减效果(含Exif元数据欺骗指令集)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;胶片叙事与数字时代的时间诗学 胶片影像的物理性——帧率、显影时长、机械快门延时——曾将时间锚定为可触摸的物质存在&#xff1b;而数字媒介则以纳秒级采样、无损复制与非线性剪辑&#xff0c;将时间…...

避开这些坑,你的YOLO论文才能发得快!目标检测老鸟的实战避坑与效率工具清单

YOLO论文高效产出指南&#xff1a;目标检测老手的避坑策略与工具链实战 实验室的灯光在凌晨三点依然亮着&#xff0c;屏幕上YOLOv8的loss曲线却像心电图一样毫无规律地跳动着。这已经是本周第三次复现顶会论文失败&#xff0c;而距离截稿日期只剩三周。如果你也经历过这种"…...

峰值电流模式控制中传播延迟的功率影响与补偿方案

1. 项目概述&#xff1a;直面峰值电流模式控制的“功率之殇”做电源设计&#xff0c;尤其是反激式开关电源&#xff0c;有一个场景大家肯定都遇到过&#xff0c;而且非常头疼&#xff1a;你的电源在最低输入电压&#xff08;比如85VAC&#xff09;下&#xff0c;各项指标都调得…...

FPGA开发入门:从零开始用Vivado实现LED流水灯项目

1. 项目概述与核心价值最近在后台和社群里&#xff0c;看到不少刚接触FPGA开发的朋友&#xff0c;特别是从单片机或嵌入式软件转过来的&#xff0c;对于如何上手第一个完整的FPGA项目感到有些迷茫。大家常问&#xff1a;“我学了Verilog语法&#xff0c;也跑过仿真了&#xff0…...

5分钟掌握Snap.Hutao:免费开源的Windows原神桌面工具箱完全指南

5分钟掌握Snap.Hutao&#xff1a;免费开源的Windows原神桌面工具箱完全指南 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 &#x1f9f0; / Multifunctional Open-Source Genshin Impact Toolkit &#x1f9f0; 项目地址: https://gitcode.com/GitHub_Trending/sn…...