zoukankan      html  css  js  c++  java
  • POJ 2392 Space Elevator(多重背包 + 倍增优化)

    题意:

     用 k 种材料搭建一个梯子,每种材料有高度,数量,最大到达高度等参数限制,求这 k 种材料最多能搭建多高的梯子。

    思路:

     多重背包,由于 dp 数组的无后效性,所以要对梯子的最大可到达高度进行从小到达排序,然后再进行多重背包即可。

    #include <iostream>
    #include <algorithm>
    using namespace std;
    
    const int MAXN = 410;
    const int MAXD = 40010;
    
    struct BlockInfo {
        int h, a, c;
        bool operator < (const BlockInfo& other)
        { return a < other.a; }
    } type[MAXN] ;
    
    int dp[MAXD];
    
    void ZeroOnePack(int w, int val, int vol)
    {
        for (int v = vol; v >= w; --v)
            dp[v] = max(dp[v], dp[v - w] + val);
    }
    
    void CompletePack(int w, int val, int vol)
    {
        for (int v = w; v <= vol; ++v)
            dp[v] = max(dp[v], dp[v - w] + val);
    }
    
    void MultiplyPack(int w, int val, int num, int vol)
    {
        if (w * num >= vol)
        {
            CompletePack(w, val, vol);
            return ;
        }
    
        int k = 1; 
        while (k <= num)
        {
            ZeroOnePack(w * k, val * k, vol);
            num -= k;
            k <<= 1;
        }
        if (num)
            ZeroOnePack(w * num, val * num, vol);
    }
    
    int main()
    {
        int n;
        scanf("%d", &n);
        for (int i = 0; i < n; ++i)
            scanf("%d %d %d", &type[i].h, &type[i].a, &type[i].c);
    
        sort(type, type + n);
    
        for (int i = 0; i < n; ++i)
        {
            MultiplyPack(type[i].h, type[i].h, type[i].c, type[i].a);
    
            for (int v = type[i].a; v <= type[n-1].a; ++v)
                dp[v] = dp[type[i].a];
        }
    
        printf("%d\n", dp[type[n-1].a]);
        return 0;
    }
  • 相关阅读:
    几种简单的素数判定法(转)
    在Ubuntu下编译WebKit源码
    Struts2+JSON特别让人恶心的一个问题
    强大的asp.net 绑定组件
    关于单点登陆的示例代码
    NHibernate 如何高效的数据翻页?
    FLEX学习网站大全
    pku1207
    windows7试用过程常见问题解答
    什么是HTTPS?
  • 原文地址:https://www.cnblogs.com/kedebug/p/2908248.html
Copyright © 2011-2022 走看看