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

【习题 8-1 UVA - 1149】Bin Packing

时间:2018-01-05 15:47:48      阅读:95      评论:0      收藏:0      [点我收藏+]

标签:pre   dea   递增   mes   break   http   for   seve   pen   

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


在这里输入题意

【题解】


每个背包只能装两个东西。
而且每个东西都要被装进去。
那么我们随意考虑某个物品。(不必要求顺序
这个物品肯定要放进某个背包里面的。
那么背包数递增。
那么剩余的空间。
只能装一个了。
要装谁呢?
肯定是尽可能装较大的.所以用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 - 1149】Bin Packing

标签:pre   dea   递增   mes   break   http   for   seve   pen   

原文地址:https://www.cnblogs.com/AWCXV/p/8203450.html

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