蓝桥杯刷题第二天——背包问题

embedded/2025/1/18 16:52:12/

题目描述

有N件物品和一个容量是V的背包。每件物品只能使用一次。第i件物品的体积是Vi价值是Wi。

求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。
输出最大价值。

输入格式

第一行两个整数,N,V,用空格隔开,分别表示物品数量和背包容积。
接下来有N行,每行两个整数,W,用空格隔开,分别表示第件物品的体积和价值。

输出格式

输出一个整数,表示最大价值。

数据范围

0< N,V≤ 1000
0<v,W≤1000

解题思路

此题可用动态规划来解决。

1.首先定义一个二维数组组dp[i][j],表示前i个物品放入容量为j的背包中能获得的最大价值。

2.状态转移方程为:dp[i][j]=max(dp[i-1][j],dp[i-1][j-v[i]]+w[i]],其中v[i] 和 w[i] 分别是第i个物品的体积和价值。这个方程的含义是,对于第i个物品,有两种选择:不放入背包(价值为dp[i-1][j]),或者放入背包(价值为dp[i-1][j-v[i]]+w[i]),取两者中的较大值。

3.边界条件:当i=或=时,dp[i][j]=,即没有物品或者背包容量为0时,最大价值为 0。

代码示例

N, V = map(int, input().split())
dp = [[0] * (V + 1) for _ in range(N + 1)]
for i in range(1, N + 1):v, w = map(int, input().split())for j in range(1, V + 1):dp[i][j] = dp[i - 1][j]if j >= v:dp[i][j] = max(dp[i][j], dp[i - 1][j - v] + w)
print(dp[N][V])

结果展示


http://www.ppmy.cn/embedded/154993.html

相关文章

effective-Objective-C 第二章阅读笔记

对象&#xff0c;消息&#xff0c;运行期 文章目录 对象&#xff0c;消息&#xff0c;运行期前言理解“属性”这一概念属性修饰符原子性nonatimicatomic 读/写权限内存管理语义方法名 自定义初始化方法小结 在对象内部尽量直接访问实例变量小结 对象等同性特定类的isEqual执行深…

机器学习:监督学习与非监督学习

监督学习是利用带有标签的数据进行训练,模型通过学习输入和输出之间的关系来进行预测。也就是说,数据集中既有输入特征,也有对应的输出标签,模型的目标是找到从输入到输出的映射关系。 而无监督学习则使用没有标签的数据进行训练,模型的任务是发现数据中的内在结构或模式…

Go实现设计模式

1、是什么 设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结&#xff0c;使用设计模式是为了可重用代码、让代码更容易被他人理解并且保证代码可靠性。 通俗来说&#xff1a;是一个项目的代码层面设计架构&#xff0c;代码功能的排…

reac 后端接口返回二进制文件流前端导出文件

axios配置 在你的请求中加入 responseType:blob导出函数 export interface DownloadFileOptions {filename: string; //文件名称}/*** 下载二进制文件流* param data - 二进制数据* param options - 下载配置*/export const downloadBinaryFile1 (data: any, // 这里使用 a…

ASP .NET Core 学习(.NET9)配置接口访问路由

新创建的 ASP .NET Core Web API项目中Controller进行请求时&#xff0c;是在地址:端口/Controller名称进行访问的&#xff0c;这个时候Controller的默认路由配置如下 访问接口时&#xff0c;是通过请求方法&#xff08;GET、Post、Put、Delete&#xff09;进行接口区分的&…

2025年01月16日Github流行趋势

项目名称&#xff1a;tabby 项目地址url&#xff1a;https://github.com/TabbyML/tabby 项目语言&#xff1a;Rust 历史star数&#xff1a;27449 今日star数&#xff1a;1439 项目维护者&#xff1a;wsxiaoys, apps/autofix-ci, icycodes, liangfung, boxbeam 项目简介&#xf…

替换数据库不是谁好就用谁

哪个数据库优秀不一定都能达成一致的意见 在1.4日的PG上海生态大会上&#xff0c;我发言大致是&#xff1a;每个人都有自己主观意愿。比如MySQL和PG的争论&#xff0c;无论线上还是线下都是难解难分。主观意愿定了&#xff0c;很难改变。即使心里认&#xff0c;但是嘴上也不说…

msxml安装失败怎么办,如何解决

当MSXML安装失败时&#xff0c;可以尝试以下几种方法来解决这个问题&#xff1a; 一、检查并修复系统文件 系统文件的损坏可能会阻止MSXML的安装。此时&#xff0c;可以使用系统文件检查器&#xff08;SFC&#xff09;来扫描并修复可能损坏的系统文件。具体步骤如下&#xff1…