习题 8-1 UVA - 1149Bin Packing

Posted Visitor

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了习题 8-1 UVA - 1149Bin Packing相关的知识,希望对你有一定的参考价值。

【链接】 我是链接,点我呀:)
【题意】


在这里输入题意

【题解】


每个背包只能装两个东西。
而且每个东西都要被装进去。
那么我们随意考虑某个物品。(不必要求顺序
这个物品肯定要放进某个背包里面的。
那么背包数递增。
那么剩余的空间。
只能装一个了。
要装谁呢?
肯定是尽可能装较大的.所以用upper_bound-1找一个最大的能装的装就可以了。
这样就能尽量减少体积较大的物品了。

【代码】

/*
    1.Shoud it use long long ?
    2.Have you ever test several sample(at least therr) yourself?
    3.Can you promise that the solution is right? At least,the main ideal
    4.use the puts("") or putchar() or printf and such things?
    5.init the used array or any value?
    6.use error MAX_VALUE?
    7.use scanf instead of cin/cout?
    8.whatch out the detail input require
*/
/*
    一定在这里写完思路再敲代码!!!
*/
#include <bits/stdc++.h>
using namespace std;

const int N = 1e5;

int n,l;
multiset<int> myset;

int main(){
    #ifdef LOCAL_DEFINE
        freopen("rush_in.txt", "r", stdin);
    #endif
    ios::sync_with_stdio(0),cin.tie(0);
    int T;
    cin >> T;
    int kase = 0;
    while (T--){
        if (kase>0) cout << endl;
        kase++;
        myset.clear();
        cin >> n >> l;
        for (int i = 1;i <= n;i++) {
            int x;
            cin >> x;myset.insert(x);
        }
        int cnt = 0;
        for (int i = 1;i <= n;i++){
            if (myset.empty()) break;
            int x = (*myset.begin());
            myset.erase(myset.begin());
            cnt++;
            auto idx = myset.upper_bound(l-x);
            if (idx==myset.begin()) continue;
            idx--;
            myset.erase(idx);
        }
        cout << cnt << endl;
    }
    return 0;
}

以上是关于习题 8-1 UVA - 1149Bin Packing的主要内容,如果未能解决你的问题,请参考以下文章

UVa 1149 - Bin Packing

UVa 1149 Bin Packing 题解

Uva1149

UVa 1149 装箱

习题3-4 周期串 UVa455

UVa 12100 Printer Queue (习题 5-7)