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

题目描述

有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])

结果展示

相关推荐
2301_765703141 分钟前
深入理解Python的if __name__ == ‘__main__‘
jvm·数据库·python
浒畔居3 分钟前
使用Docker容器化你的Python应用
jvm·数据库·python
有一个好名字11 分钟前
力扣-省份数量
python·算法·leetcode
爱学习的阿磊15 分钟前
Python迭代器(Iterator)揭秘:for循环背后的故事
jvm·数据库·python
iAkuya16 分钟前
(leetcode)力扣100 55全排列
算法·leetcode·职场和发展
喵手19 分钟前
Python爬虫实战:论坛社区数据采集实战:从主题列表到分页回帖爬取(附CSV导出 + SQLite持久化存储)!
爬虫·python·sqlite·爬虫实战·零基础python爬虫教学·论坛社区数据采集·csv采集数据导出
工程师老罗25 分钟前
PyTorch transforms的用法
人工智能·pytorch·python
2401_8414956425 分钟前
【强化学习】REINFORCE 算法
人工智能·python·算法·强化学习·reinforce·策略梯度·蒙特卡洛
喵手33 分钟前
Python爬虫实战:构建企业级的招投标信息监控工具,多页动态数据抓取,实现去重增量更新(附SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·sqlite持久化存储·采集招投标信息·多页动态数据抓取
虎头金猫1 小时前
内网导航站 “出圈”!用 cpolar 解锁 Dashy 远程访问新玩法
java·c++·python·程序人生·职场和发展·php·程序员创富