zoukankan      html  css  js  c++  java
  • 106.运输装备(二维01背包)


    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

    分类标签 Tags 点此展开 

    分析:对于01背包有n个约束条件,就开一个n维的数组,每一维是一个约束条件,
    循环的时候再加上一重就可以了,加的这个循环也是在物品循环的内部。
    代码:
    #include< iostream >
    #include< cstdio >
    using namespace std;
    int f[1001][1001],V,G,n,ti[1001],v[1001],g[1001];
    void input()
    {
    scanf("%d%d%d",&V,&G,&n);
    for(int i=1;i<=n;++i)
    scanf("%d%d%d",&ti[i],&v[i],&g[i]);
    }
    int main()
    {
    input();
    for(int i=1;i<=n;++i)
     for(int j=V;j>0;j--)
       for(int k=G;k>0;--k)
       if(j-v[i]>=0&&k-g[i]>=0)
        f[j][k]=max(f[j][k],f[j-v[i]][k-g[i]]+ti[i]);
        printf("%d ",f[V][G]);
    return 0;
     
  • 相关阅读:
    500 多个 Linux 命令文档搜索
    C++ 字符串基本操作
    串的模式匹配算法
    查看、启动、关闭防火墙
    天润融通面试
    LeetCode 169. 求众数
    【面试题】人人车一次面试总结
    一个完整的 JS 身份证校验代码
    oracle多表查询
    百度地图的Icon
  • 原文地址:https://www.cnblogs.com/c1299401227/p/5370710.html
Copyright © 2011-2022 走看看