11083 旅游背包(优先做)

这个问题可以使用动态规划来解决。我们可以定义一个三维数组dp,其中dp[i][j][k]表示前i种物品,总体积不超过j,总重量不超过k的最大价值。

我们可以使用四重循环来填充这个数组。外层循环遍历所有的物品,第二层循环遍历所有可能的体积,第三层循环遍历所有可能的重量,内层循环遍历当前物品的所有可能的数量。

在填充数组的过程中,我们需要考虑两种情况:一种是不选择当前的物品,那么dp[i][j][k]就等于dp[i-1][j][k];另一种是选择当前的物品,那么dp[i][j][k]就等于dp[i-1][j-v[i]*l][k-w[i]*l] + t[i]*l,其中l是当前物品的数量。

以下是一个使用C++实现的解决方案:

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;const int MAXN = 55;
const int MAXV = 1005;
const int MAXW = 505;
int v[MAXN], w[MAXN], c[MAXN], t[MAXN];
int dp[MAXN][MAXV][MAXW];int main() {int n, V, W;cin >> n >> V >> W;for (int i = 1; i <= n; i++) {cin >> v[i] >> w[i] >> c[i] >> t[i];}for (int i = 1; i <= n; i++) {for (int j = 0; j <= V; j++) {for (int k = 0; k <= W; k++) {dp[i][j][k] = dp[i-1][j][k];for (int l = 1; l <= c[i] && l * v[i] <= j && l * w[i] <= k; l++) {dp[i][j][k] = max(dp[i][j][k], dp[i-1][j-l*v[i]][k-l*w[i]] + l*t[i]);}}}}cout << dp[n][V][W] << endl;return 0;
}


这个程序首先读取输入的n,V和W,然后读取每种物品的体积,重量,数量和价值。然后,它使用四重循环来填充dp数组。在填充数组的过程中,它会考虑两种情况:一种是不选择当前的物品,另一种是选择当前的物品。最后,它输出dp[n][V][W],即前n种物品,总体积不超过V,总重量不超过W的最大价值。

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

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

相关文章

2024软件设计师笔记之考点版(一考就过):考试前一天 考点记忆版

软件设计师之一考就过&#xff1a;成绩版 1、栈区&#xff1a;函数调用和返回&#xff0c;由系统控制&#xff1b;存非静态局部变量&#xff1b;用栈实现嵌套调用&#xff08;递归调用&#xff09;&#xff0c;逆波兰式业绩也叫后缀式&#xff0c;用栈进行求值 2、堆区&#x…

windows创建符号链接

1.进入cmd 2.创建链接到文件的符号链接 mklink 目标文件 源文件 3.创建链接到目录的符号链接 mklink /d 目标文件夹 源文件夹

ES6的新特性有哪些

1. 新增了块级作用域&#xff08;let&#xff0c;const&#xff09; 2. 新增了定义类的语法糖&#xff08;class&#xff09; 3. 新增了一种基本数据类型&#xff08;symbol&#xff09; 4. 新增了解构赋值 5. 新增了函数参数的默认值 6. 给数组新增了API 7. 对象和数组新增了扩…

Big Data Tools插件

一些介绍 在Jetbrains的产品中&#xff0c;均可以安装插件&#xff0c;其中&#xff1a;Big Data Tools插件可以帮助我们方便的操作HDFS&#xff0c;比如 IntelliJ IDEA&#xff08;Java IDE&#xff09; PyCharm&#xff08;Python IDE&#xff09; DataGrip&#xff08;SQL …

【RabbitMQ问题踩坑】RabbitMQ设置手动ack后,消息队列有多条消息,只能消费一条,就不继续消费了,这是为什么 ?

现象&#xff1a;我发送5条消息到MQ队列中&#xff0c;同时&#xff0c;我在yml中设置的是需要在代码中手动确认&#xff0c;但是我把代码中的手动ack给关闭了&#xff0c;会出现什么情况&#xff1f; yml中配置&#xff0c;配置需要在代码中手动去确认消费者消费消息成功&…

教学技能大赛包括哪些内容

在教育的广阔天地里&#xff0c;教师的角色至关重要。他们不仅是知识的传递者&#xff0c;更是学生心灵成长的引导者。那么&#xff0c;当教师们聚集一堂&#xff0c;参加一场教学技能大赛时&#xff0c;会有哪些内容成为他们展示自我、互相学习的舞台呢&#xff1f; 教学技能大…

盛科7132版本编译记录

7132编译总结&#xff1a; 1.新增具有root权限的用户&#xff0c;rootfs系统编译时不能使用root&#xff0c;否则很麻烦&#xff0c;编译出来后命令使用会出问题 useradd zhuwei_new passwd zhuwei_new usermod -aG wheel zhuwei_new nano /etc/pam.d/su 找到以下…

为什么要禁用透明大页面

在安装CDH&#xff08;Clouderas Distribution Including Apache Hadoop&#xff09;环境时&#xff0c;禁用透明大页面&#xff08;Transparent HugePages&#xff0c;THP&#xff09;是一个推荐的系统优化步骤。以下是禁用透明大页面的一些原因&#xff1a; 1. **性能影响**…

瓦罗兰特报错57/error code59/报错903的解决办法

《无畏契约》在注重产品设计之预&#xff0c;也注重世界观、英雄性格的塑造&#xff0c;里面的英雄灵感来源于不同的国家和地区&#xff0c;有非常本土化的特色&#xff0c;每个英雄的性格人设非常鲜明。这些人物特色让这款游戏有了新的玩法。很多玩家都进入到游戏体验。然后有…

SeeSR: Towards Semantics-Aware Real-World Image Super-Resolution

CVPR2024 香港理工大学&OPPO&bytedancehttps://github.com/cswry/SeeSR?tabreadme-ov-file#-licensehttps://arxiv.org/pdf/2311.16518#page5.80 问题引入 因为有些LR退化情况比较严重&#xff0c;所以超分之后的结果会出现语义的不一致的情况&#xff0c;所以本文训…

微信小程序实现双向数据绑定

微信小程序实现了类似Vue.js的双向数据绑定机制&#xff0c;允许你在WXML模板中绑定数据源&#xff0c;并在数据变化时自动更新视图。尽管其内部实现与Vue.js不同&#xff0c;但对开发者而言&#xff0c;使用体验是相似的。 如何在微信小程序中实现双向数据绑定&#xff1a; 定…

Android SurfaceFlinger——系统动画服务启动(十四)

在了解了 SurfaceFlinger、HWC、OpenGL ES 和 EGL 等相关概念和基础信息后,我们通过系统动画的调用流程引入更多的内容。 一、解析init.rc 开机就启动进程,肯定就要从 rc 文件开始。负责开机动画的进程是 bootanimation。 1、bootanim.rc 源码位置:/frameworks/base/cmds…

vue中避免多次请求字典接口

vuex缓存所有字典项 背景vuex管理所有字典项调用字典接口处理字典项数据的filter页面中使用字典 背景 每次用到字典都需要通过对应的字典type调用一次字典接口&#xff0c;当一个页面用到字典项很多时&#xff0c;接口请求炒鸡多&#xff0c;会导致接口响应超时。 本篇文章改为…

Python入门 2024/7/1

目录 第一个程序hello world 数据类型 注释 变量 用type类型查看数据类型 ​编辑 数据类型转换 ​编辑 标识符 运算符 字符串的三种定义方式 字符串拼接 ​编辑​编辑 字符串格式化 第一个程序hello world 区分c和python c是printf python是print print("h…

图论·Bellman_ford算法

无负权回路例题 带负权回路例题 Bellman_ford算法 适用条件 单源最短路径存在负权值边检测负权回路 核心操作 松弛&#xff1a;对每条边与源点的距离重新计算 if (dist[item.v1] ! INT_MAX && dist[item.v1] item.w < dist[item.v2]) {dist[item.v2] dist[i…

晶振在硬件系统中的位置选择与优化策略

在现代电子设备中&#xff0c;晶振扮演着至关重要的角色&#xff0c;它们提供稳定且精确的时钟信号&#xff0c;是系统心脏般的存在。然而&#xff0c;晶振的性能不仅取决于其本身的质量&#xff0c;还与它在硬件系统中的位置选择紧密相关。一个恰当的位置能够最大限度地减少外…

基于K线最短路径构造的非流动性因子

下载地址https://download.csdn.net/download/SuiZuoZhuLiu/89492221

软件工程简答

什么是软件工程 软件工程&#xff1a;将系统化的、规范的、可量化的方法应用于软件的开发、运行和维护&#xff0c;即将工程化方法应用于软件。支持软件工程的根基在于质量关注点。 软件工程的基础是过程层&#xff0c;将各个技术层次结合在一起。方法层为构建软件提供技术上的…

springboot调用wsdl接口

springboot调用wsdl接口 maven依赖 <!--xml报文数据--><dependency><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>jackson-dataformat-xml</artifactId><version>2.9.8</version></dependency><…

nodejs--【Express基本使用】

10 【Express基本使用】 https://www.expressjs.com.cn/ 基于 Node.js 平台&#xff0c;快速、开放、极简的 web 开发框架。 1.Express的安装方式 Express的安装可直接使用npm包管理器上的项目&#xff0c;在安装npm之前可先安装淘宝镜像&#xff1a; npm install -g cnpm -…