码迷,mamicode.com
首页 > 其他好文 > 详细

Codevs1669运输装备题解

时间:2015-07-02 19:31:56      阅读:143      评论:0      收藏:0      [点我收藏+]

标签: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

  • 数据范围
    对于50%的数据,V,G,N≤100
    对于100%的数据,V,G,N≤1000

  • 题解
    二维费用背包问题,本题满足01背包的模型,只需把状态再开一维,同时存储体积和重量即可。状态转移方程和枚举顺序几乎和普通01背包相同。

  • 启示
    当发现新题目是由熟悉的动态规划题目变形得来时,在原来的状态中加一维以满足新的限制是一种比较常用的方法。

  • Code

#include <cstdio>
#include <algorithm>
using namespace std;
const int maxn = 1010;
int V, G, N, v[maxn], g[maxn], w[maxn];
int f[maxn][maxn];
void init()
{
    scanf("%d%d%d", &V, &G, &N);
    for(int i = 1; i <= N; ++i)
    {
        scanf("%d%d%d", &w[i], &v[i], &g[i]);
    }
}
void work()
{
    for(int i = 1; i <= N; ++i)
    {
        for(int j = V; j >= v[i]; --j)
        {
            for(int k = G; k >= g[i]; --k)
            {
                f[j][k] = max(f[j][k], f[j - v[i]][k - g[i]] + w[i]);
            }
        }
    }
    printf("%d\n", f[V][G]);
}
int main()
{
    init();
    work();
    return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

Codevs1669运输装备题解

标签:dp   背包   二维费用   

原文地址:http://blog.csdn.net/t14t41t/article/details/46729291

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!