codevs #1669 运输装备(dp)
来源:互联网 发布:圣元 国际财报数据 编辑:程序博客网 时间:2024/05/18 00:22
引言
这只是一道简单的dp题,不过为了交作业,还是得打上来。。。
原题链接:http://codevs.cn/problem/1669/
标签:dp
题意描述
题目描述 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 3
样例输出 Sample Output
50
数据范围及提示 Data Size & Hint
对于50%的数据,V,G,N≤100
对于100%的数据,V,G,N≤1000
分析
这是一道二维的背包问题,所以用f[i][j]来表示装i重量,j体积可获得的最大火力值。
显然地,用i枚举每件物品,p表示当前体积,q表示当前重量,那么转移方程就是
其中t[i],v[i],g[i]如题意描述。
因为是01背包问题,所以需要反着推,最后输出f[v][g]即可。
时间复杂度为O(VGN)
代码
#include<cstdio>#include<algorithm>using namespace std;#define maxn 1050int vv,gg,i,v[maxn],t[maxn],g[maxn],f[maxn][maxn],n,j,k;int main(){ scanf("%d%d\n",&vv,&gg); scanf("%d\n",&n); for (i=1;i<=n;i++) scanf("%d%d%d",&t[i],&v[i],&g[i]); for (i=1;i<=n;i++) for (j=vv;j>=v[i];j--) for (k=gg;k>=g[i];k--) f[j][k]=max(f[j][k],f[j-v[i]][k-g[i]]+t[i]); printf("%d",f[vv][gg]); return 0;}
- codevs #1669 运输装备(dp)
- 1669 运输装备(codevs)
- Codevs 1669 运输装备
- Codevs 1669 运输装备
- Codevs P1669 运输装备
- 1669 运输装备(cv)
- 1669 运输装备
- 运输装备
- Code[VS] 1669 运输装备 解题报告
- Codevs1669运输装备题解
- 作业7:运输装备
- Luogu P1794 装备运输
- 货车运输(codevs 3287)题解
- 买装备(dp,背包)
- oj 作业7 运输装备
- [codevs 1914] 运输问题
- Codevs 3287 货车运输
- Codevs P1655 物流运输
- C++中的class和typename
- CDOJ 1307 ABCDE dp, 前缀和优化
- 自我介绍
- hive启动问题解决方法
- Matlab中的()【】{}
- codevs #1669 运输装备(dp)
- 几种最短路径算法的比较
- [HDU3842]Machine Works
- 并发编程——线程同步
- 旋转游戏
- 正则表达式基本语法
- 杭电ACM1009
- matlab命令行中双箭头消失怎么办
- ArrayList和LinkedList的时间复杂度