• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            pku 3497 Assemble 二分+模擬+STL

            題意:
            若干電腦配件,若干型號,每個(gè)型號都有價(jià)格和性能指數(shù)。求在K錢內(nèi)的配置方案,使得最差性能最好。。
            解法:
            二分+判斷
            代碼:

             1# include <cstdio>
             2# include <string>
             3# include <cstring>
             4# include <map>
             5# include <set>
             6# include <algorithm>
             7# include <vector>
             8using namespace std;
             9struct node
            10{
            11   string name;
            12   int p,q;
            13   node(string na,int pr,int qu):name(na),p(pr),q(qu) {};
            14}
            ;
            15struct cmp
            16{
            17   bool operator()(const node &a,const node &b) const
            18   {
            19        return a.name<b.name;
            20   }

            21}
            ;
            22int n,m;
            23map<string,vector<node> >data;
            24vector<int> refer;
            25bool chk(int mid)
            26{
            27   long long total=0;
            28   for(map<string,vector<node> >::iterator i=data.begin();i!=data.end();i++)
            29   {
            30      int tp=0xfffffff;
            31      for(vector<node>::iterator j=(i->second).begin();j!=(i->second).end();j++)
            32        if(j->q>=mid&&j->p<tp)
            33           tp=j->p;
            34      total+=tp;
            35   }

            36   return total<=(long long)m;
            37}

            38int main()
            39{
            40    int test;
            41    scanf("%d",&test);
            42    while(test--)
            43    {
            44       scanf("%d%d",&n,&m);
            45       data.clear();
            46       refer.clear();
            47       for(int i=0;i<n;i++)
            48       {
            49          char type[128],name[128];
            50          int p,q;
            51          scanf("%s%s%d%d",type,name,&p,&q);
            52          data[string(type)].push_back(node(string(name),p,q));
            53          refer.push_back(q);
            54       }

            55       sort(refer.begin(),refer.end());
            56       vector<int>::iterator end=unique(refer.begin(),refer.end());
            57       while(refer.end()!=end) refer.pop_back();
            58       int s=0,e=refer.size()-1;
            59       while(s<=e)
            60       {
            61          int mid=(s+e)>>1;
            62          if(chk(refer[mid])) s=mid+1;
            63          else e=mid-1;
            64       }

            65       printf("%d\n",refer[s-1]);
            66    }

            67    return 0;
            68}

            69
            70

            posted on 2010-12-02 22:42 yzhw 閱讀(122) 評論(0)  編輯 收藏 引用 所屬分類: data struct

            <2010年12月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            統(tǒng)計(jì)系統(tǒng)

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久综合给合久久狠狠狠97色 | 色88久久久久高潮综合影院 | 国产亚洲美女精品久久久2020| 亚洲午夜久久久精品影院| 国内精品久久久久久久97牛牛| 国产精品成人久久久| 欧美激情一区二区久久久| 久久香综合精品久久伊人| 一本一本久久a久久综合精品蜜桃| 亚洲欧美一区二区三区久久| 女人高潮久久久叫人喷水| 国产成人综合久久精品红| 久久人妻无码中文字幕| 性欧美大战久久久久久久久| 久久精品aⅴ无码中文字字幕不卡| 国产色综合久久无码有码| 99精品久久精品一区二区| 无遮挡粉嫩小泬久久久久久久| 久久er99热精品一区二区| 精品一区二区久久| 久久国产香蕉一区精品| 欧美国产成人久久精品| 久久av无码专区亚洲av桃花岛| 国产成人久久精品区一区二区| 国产2021久久精品| 欧美精品国产综合久久| 精品国产乱码久久久久久1区2区| 久久综合九色综合久99 | 一级a性色生活片久久无| 7777久久久国产精品消防器材| 精品国产91久久久久久久| 国产免费久久久久久无码| 成人午夜精品无码区久久| 99久久久精品免费观看国产| 久久精品女人天堂AV麻| 亚洲AV日韩精品久久久久久 | 亚洲午夜精品久久久久久人妖| 亚洲国产精品综合久久网络| MM131亚洲国产美女久久| 日本高清无卡码一区二区久久 | 伊人久久大香线蕉无码麻豆 |