• Codevs 1669 运输装备


    时间限制: 1 s
     空间限制: 256000 KB
     题目等级 : 钻石 Diamond
     
     
    题目描述 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

    代码:

    #include<iostream>
    #include<cstdio>
    #include<cstring> 
    #define NN 1010
    using namespace std;
    int G,V,v[NN],t[NN],n,g[NN],f[NN][NN];
    int main()//G-- 重量    V --体积 
    {
        scanf("%d%d",&V,&G);
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
          cin>>t[i]>>v[i]>>g[i];
        for(int i=1;i<=n;i++)
          for(int j=G;j>=g[i];j--)
            for(int k=V;k>=v[i];k--)
              f[j][k]=max(f[j][k],f[j-g[i]][k-v[i]]+t[i]);
        printf("%d",f[G][V]);
        return 0;
     } 

    思路:

    题目输入描述有问题,简单的二维费用背包...

  • 相关阅读:
    数据库数据格式化之Kettle Spoon
    NopCommerce开源项目中很基础但是很实用的C# Helper方法
    oracle 两个逗号分割的字符串 如何判断是否其中有相同值
    MongoDB+MongoVUE安装及入门
    C#中Dictionary<TKey,TValue>排序方式
    kettle的基本介绍
    Kettle能做什么?
    oracle like 条件拼接
    loading加载和layer.js
    关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值
  • 原文地址:https://www.cnblogs.com/suishiguang/p/5837595.html
Copyright © 2020-2023  润新知