01背包问题 刷题笔记

思路 dp
用f[i][j]来表示当体积为j时 考虑前i件物品可以获得的 最大值
记住f[i][j]本身是个价“价值”
考虑两种状态 是否将第i件物品放入背包里面
将背包的体积从小到大递增来进行考虑
首先 考虑条件 如果当前增加的体积放不下下一件物品
则该体积 可以获得的最大值可以直接继承上一个f[i-1][j]
如果可以放下 则比较 放入与不放入谁获得的值较大
即 f[i-1][j]与f[i-1][j-v[i]]+w[i]比较
//-v[i]是为了减去放入后的背包体积
加w[i]是为了加上放入后获得的价值
每一次存下的 都是基于考虑到当前物品 的最优选择
比方说 前面已经进行了i件物品的选择
获得了一个基于i件物品的最大值
这时候 第i+1件物品突然出现 体积为1,价值1000000;
那么当背包体积只有1时的最大值会立刻被更新成100000;
此时仍然是最优选择
代码
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
using namespace std;
const int N=1010;
int f[N][N];
int w[N],v[N];
int n,m;
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>v[i]>>w[i];
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(j<v[i]){
f[i][j]=f[i-1][j];
}else{
f[i][j]=max(f[i-1][j],f[i-1][j-v[i]]+w[i]);
}
}
}
cout<<f[n][m];
return 0;
}
优化思路
二维到一维
我们发现 考虑第i件物品时的最大值来自前面一层i-1件物品的最大值
也就是说 所有的当前层 都只来自上一层的最大值
而上上层已经不重要了
因此有没有可能直接删掉层数记录
观察发现f[i][]是从f[i-1][]这一层更新出来的
此时我们直接删除i
只使用j
观察式子f[j-v[i]]+w[i]
也就是说 如果我们逆序更新的话 需要使用和比较的数是j-v[i]
这个数是绝对小于j的 如果将j从m往0更新
保证了更新时只有大于等于j的数被覆盖掉了
而我们需要用的 j-v[i]则被保留下来
举例
如果我们逆序更新的话
假设 原来 f[j](1-5)是
1 2 5 7 9
然后我们逆序更新
for(int i=0;i<n;i++){
for(int j=m;j>=v[i];j--){
f[j]=max(f[j],f[j-v[i]]+w[i]);
}
}
假设 此时j=5,v[i]=2, f[j-v[i]]+w[i]=11那么
我们和上一个f[3]比较 比较完了以后将上一个f[5]覆盖掉
此时f[j](1-5)的情况为
1 2 5 7 11
然后当j=4;
v[i]=1;
f[j-v[i]]+w[i]=9;
即我们需要用的是f[3]
此时f[3]并没有被污染
执行以后
f[j](1-5)的情况为
1 2 5 9 11
以此类推我们的目的达到了
代码
#include<bits/stdc++.h>
using namespace std;
const int N=1010;
int f[N];
int w[N],v[N];
int j[N];
int n,m;
int main(){
cin>>n>>m;
for(int i=0;i<n;i++){
//int x,y;
cin>>v[i]>>w[i];
//v[i]=x;
//w[i]=y;
}
for(int i=0;i<n;i++){
for(int j=m;j>=v[i];j--){
f[j]=max(f[j],f[j-v[i]]+w[i]);
}
}
cout<<f[m];
return 0;
相关文章:
01背包问题 刷题笔记
思路 dp 用f[i][j]来表示当体积为j时 考虑前i件物品可以获得的 最大值 记住f[i][j]本身是个价“价值” 考虑两种状态 是否将第i件物品放入背包里面 将背包的体积从小到大递增来进行考虑 首先 考虑条件 如果当前增加的体积放不下下一件物品 则该体积 可以获得的最大值可以直接…...
docker安装包(Linux和windows)
Linux——docker-20.10.9.tgz 网盘地址:链接:https://pan.baidu.com/s/1T3qfVZ-uT-vMAo8w6heTMw 提取码:qu85 windows——docker19.03.1 链接:https://pan.baidu.com/s/1mK6hqhkGCBs6tdBHJxrdPw 提取码:4dkj...
RabbitMQ 安装使用
文章目录 RabbitMQ 安装使用安装下载 Erlang下载 RabbitMQ 的服务安装好后看是否有 RabbitMQ 的服务开启管理 UIRabbitMQ 端口使用一览图 使用输出最简单的 Hello World!生产者定义消费者消费消息小拓展 RabbitMQ 安装使用 安装 下载 Erlang RabbitMQ 是用这个语…...
echarts x轴名称过长tip显示全称
xAxis的axisLabel的内容如下: axisLabel: { rotate: -45, color: document.body.className.indexOf(custom-f4c46d) > -1 ? #fff : #343434, // 显示省略号操作(第一步) formatter: function (value) { var val if (value.length >…...
js和css阻塞问题
面试常见问题 css 加载会不会阻塞 js 的加载?(不会)css 加载会不会阻塞 js 的执行?(会)css 加载会不会阻塞 DOM 的解析?(不会)css 加载会不会阻塞 DOM 的渲染࿱…...
MySQL 的基础操作
数据库的基础操作 1. 库操作2. 表的操作3. 数据类型 数据库是现代应用程序中至关重要的组成部分,通过数据库管理系统(DBMS)存储和管理数据。 1. 库操作 创建数据库 创建数据库是开始使用数据库的第一步。下面是一些常见的创建数据库的示例&a…...
【python进阶篇】面向对象编程(1)
面向对象编程——Object Oriented Programming,简称OOP,是一种程序设计思想。OOP把对象作为程序的基本单元,一个对象包含了数据和操作数据的函数。 在Python中,所有数据类型都可以视为对象,当然也可以自定义对象。自定…...
力扣面试经典150 —— 6-10题
力扣面试经典150题在 VScode 中安装 LeetCode 插件即可使用 VScode 刷题,安装 Debug LeetCode 插件可以免费 debug本文使用 python 语言解题,文中 “数组” 通常指 python 列表;文中 “指针” 通常指 python 列表索引 文章目录 6. [中等] 轮转…...
[密码学]入门篇——加密方式
一、概述 加密方法主要分为两大类: 单钥加密(private key cryptography):加密和解密过程都用同一套密码双钥加密(public key cryptography):加密和解密过程用的是两套密码 历史上,…...
构建前后端分离项目常用的代码
构建前后端分离项目常用的代码 1.代码生成器 import com.baomidou.mybatisplus.generator.FastAutoGenerator;import com.baomidou.mybatisplus.generator.config.OutputFile;import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;import java.util.…...
2575. 找出字符串的可整除数组(Go语言)
https://leetcode.cn/problems/find-the-divisibility-array-of-a-string/ 在看题解之前,我的代码是以下这样: package mainimport ("fmt" )func main() {fmt.Println(divisibilityArray("998244353", 3)) }func divisibilityArray…...
Redis与 Memcache区别
Redis与 Memcache区别 1 , Redis 和 Memcache 都是将数据存放在内存中,都是内存数据库。不过 Memcache 还可用于缓存 其他东西,例如图片、视频等等。 2 , Memcache 仅支持key-value结构的数据类型,Redis不仅仅支持简单的key-value类型的数据&…...
#QT(智能家居界面-界面切换)
1.IDE:QTCreator 2.实验 3.记录 (1)创建一个新界面(UI界面) (2)可以看到新加入一个ui文件,双击打开,设置窗口大小与登录界面一致 (3)加入几个PUS…...
js拓展-内置对象
目录 1. 数组对象 1.1 数组的四种方式 1.2 JS中数组的特点 1.3 常用方法 2. 日期对象 2.1 日期对象的创建 2.2 日期对象的方法 2.3 案例:输出现在的时间 3. 全局对象 3.1 字符串转换成数字类型 3.2 编码解码函数 1. 数组对象 注:数组在JS中是一…...
【李沐精读系列】GPT、GPT-2和GPT-3论文精读
论文: GPT:Improving Language Understanding by Generative Pre-Training GTP-2:Language Models are Unsupervised Multitask Learners GPT-3:Language Models are Few-Shot Learners 参考:GPT、GPT-2、GPT-3论文精读…...
Libevent的使用及reactor模型
Libevent 是一个用C语言编写的、轻量级的开源高性能事件通知库,主要有以下几个亮点:事件驱动( event-driven),高性能;轻量级,专注于网络,不如 ACE 那么臃肿庞大;源代码相当精炼、易读…...
查看Linux服务器配置
# chkconfig --list # 列出所有系统服务 # chkconfig --list | grep on # 列出所有启动的系统服务 # ifconfig # 查看所有网络接口的属性 # iptables -L # 查看防火墙设置 # route -n # 查看路由表 # netstat -lntp # 查看所有监听端口 # netstat -antp # 查看所有已经建立的连…...
【机器学习】包裹式特征选择之递归特征添加法
🎈个人主页:豌豆射手^ 🎉欢迎 👍点赞✍评论⭐收藏 🤗收录专栏:机器学习 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进…...
解决cs不能生成Linux木马的问题
要解决的问题:众所周知,msf上面的shell或者是其他的shell想反弹给cs默认情况下是只支持windows的,因为cs的监听模块默认没有linux的,但是有些主机就是用linux搭建的,这可怎么办呢。就要用到一个插件CrossC2。 下载插件…...
vue3组件通信方式
不管是vue2还是vue3,组件通信方式很重要,不管是项目还是面试都是经常用到的知识点。 vue2组件通信方式 props:可以实现父子组件、子父组件、甚至兄弟组件通信 自定义事件:可以实现子父组件通信 全局事件总线$bus:可以实现任意组件通信 pubsub:发布订阅模式实现任意组件通信…...
Windows下用Anaconda搞定CycleGAN复现:从环境配置到训练测试的保姆级避坑指南
Windows下Anaconda环境复现CycleGAN全流程实战指南 当第一次接触CycleGAN时,我被它无需配对数据就能实现图像风格转换的能力所震撼。但随之而来的环境配置问题却让许多初学者望而却步——特别是当你的主力机是Windows系统时。本文将带你避开我踩过的所有坑…...
【C# .NET 11 AI推理加速终极指南】:实测提升3.7倍吞吐量、降低62%延迟的5大硬核优化法
第一章:C# .NET 11 AI推理加速全景概览.NET 11 标志着 C# 在原生 AI 推理支持上的重大跃迁——它不再仅依赖外部 Python 运行时或 REST API 调用,而是通过深度集成 ONNX Runtime、硬件感知推理调度器与 JIT 编译优化,实现端到端的高性能、跨平…...
抖音批量下载工具技术解析:如何高效获取去水印视频与直播回放
抖音批量下载工具技术解析:如何高效获取去水印视频与直播回放 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallbac…...
机器学习Fbeta-Measure:不平衡分类评估指南
1. 机器学习中的Fbeta-Measure:理解与实战指南在机器学习分类任务中,评估模型性能是至关重要的环节。当处理不平衡分类问题时(比如欺诈检测、罕见疾病诊断等场景),传统的准确率指标往往会给出误导性的乐观结果。这时&a…...
西门子PLC工业通信的技术挑战与s7netplus解决方案
西门子PLC工业通信的技术挑战与s7netplus解决方案 【免费下载链接】s7netplus S7.NET -- A .NET library to connect to Siemens Step7 devices 项目地址: https://gitcode.com/gh_mirrors/s7/s7netplus 在工业自动化领域,西门子S7系列PLC作为主流控制设备&a…...
当你的代码卡住了:聊聊Python里的“假同步真异步”
小李今天差点把电脑砸了。他写了一个爬虫,要从一万个网站上抓数据。代码很简单:请求网址、解析内容、存进数据库。跑了十分钟,才抓了三百个。他打开任务管理器一看,CPU占用率才5%,网络流量几乎为零。“我这电脑是i9啊&…...
QuickLook OfficeViewer-Native:基于原生Office组件的文档预览解决方案
QuickLook OfficeViewer-Native:基于原生Office组件的文档预览解决方案 【免费下载链接】QuickLook.Plugin.OfficeViewer-Native View Word, Excel, and PowerPoint files with MS Office and WPS Office components. 项目地址: https://gitcode.com/gh_mirrors/q…...
别再让电机丢步了!深入解析电动变焦镜头控制中的VD_FZ信号与时序设计
高精度电动变焦镜头控制:VD_FZ信号与时序设计的工程实践 在工业相机和安防监控领域,电动变焦镜头的控制精度直接影响成像质量。当镜头在高速变焦过程中出现微小的步进丢失,可能导致对焦偏差、画面抖动甚至关键帧丢失。这种问题往往源于工程师…...
手把手教你用Python脚本绕过SQL过滤,在BUUCTF靶场实战GetShell
Python自动化SQL注入:从字符编码到实战GetShell的高级技巧 在CTF竞赛中,SQL注入始终是Web安全赛道的核心考点。当面对严格的关键词过滤时,传统的手工注入往往举步维艰。本文将深入探讨如何通过Python脚本自动化构造char()编码Payload…...
番茄小说下载神器:3步实现离线阅读自由
番茄小说下载神器:3步实现离线阅读自由 【免费下载链接】fanqienovel-downloader 下载番茄小说 项目地址: https://gitcode.com/gh_mirrors/fa/fanqienovel-downloader 还在为网络不稳定无法畅读番茄小说而烦恼吗?fanqienovel-downloader 这款开源…...
