CodeVS-1669 (背包问题)
来源:互联网 发布:centos 5.5 下载地址 编辑:程序博客网 时间:2024/06/05 07:21
题目
Description
德国放松对英国的进攻后,把矛头指向了东北——苏联。 1943年初,东线的站头进行到白热化阶段。据可靠情报,90余万德国军队在库尔斯克准备发动好大的攻势。因此,朱可夫元帅要求你立即从远东的军工厂运输大量装备支援库尔斯克前线。 列车司机告诉你,一趟列车最多可以容纳V体积的武器装备,但是你可能不能装满,因为列车承受不了那么大的重量,一趟列车最多可以承载G单位的重量。同时,军工厂仓库提供给你一份装备清单,详细记录了每件装备的体积、重量和火力。为了有效支援朱可夫元帅,你要找到一种方案,使得总火力值最大。
Input Description
第一行:V和G表示最大重量和体积。 第二行:N表示仓库有N件装备; 第三到N+2行:每行3个数Ti Vi Gi表示个装备的火力值、体积和重量;
Output Description
输出一个数,表示可能获得的最大火力值
Sample Input
6 5
4
10 2 2
20 3 2
40 4 3
30 3 3Sample Output
50
Data Size
对于100%的数据,V,G,N≤1000
分析
- 就是一个裸地背包问题,有两个限制(V/G),每个只能取或不取,问所能最大价值(t)为多少。
dp[x][y] 记录在x的体积(V),y的重量(G)以内所能取到的最大火力值 - 那么对于每个物品,可以选或不选,从后枚举
x,y ,更新一下dp[x][y]。 - 注意是从后往前枚举,因为是类似01背包问题,每最多个只能选一次,要是可以选无限个的话,就应该是从前往后枚举。
程序
#include <cstdio>int V,G,N,t[1010],v[1010],g[1010],dp[1010][1010];int main(){ scanf("%d%d%d",&V,&G,&N); for (int i=1; i<=N; i++) scanf("%d%d%d",&t[i],&v[i],&g[i]); for (int i=1; i<=N; i++){ for (int x=V; x>=v[i]; x--) for (int y=G; y>=g[i]; y--) if (dp[x][y]<dp[x-v[i]][y-g[i]]+t[i]) dp[x][y]=dp[x-v[i]][y-g[i]]+t[i]; } printf("%d",dp[V][G]);}
0 0
- CodeVS-1669 (背包问题)
- CodeVs 1669 二维背包
- codevs天梯 装箱问题 水01背包
- codevs 1025 选菜 背包问题 解题报告
- 背包型动态规划练习-codevs-1014装箱问题
- CODEVS 3269 混合背包
- codevs 2033 邮票(背包)
- 【codevs 3269】混合背包
- codevs 3269 混合背包
- 3269 混合背包(codevs)
- Codevs 3269 混合背包
- 【codevs】3269 混合背包
- codevs 3269 混合背包
- Codevs 3372 选学霸(并查集+剩余空间最小的背包问题)
- codevs 1297 硬币 (dp背包类型)
- 3269混合背包——codevs
- Codevs 3269 混合背包(二进制优化)
- Codevs 1102 采药 01背包模板
- c++编写无向图 使用容器Vector编写邻接表法
- 文章标题
- Apache Rewrite规则详解
- Kilim 简介
- 百度地图API描点
- CodeVS-1669 (背包问题)
- [SMOJ1726]染色一
- Whats is the difference between train, validation and test set, in neural networks?
- Java基础练习
- struts2if标签判断对象值是否等于指定值
- eclipse svn回滚之前版本
- linux下搭建ftp服务器
- 涿州未来五年环境、城市及交通规划,绝对靠谱!
- 解决csdn代码引起的排版问题