uva12124 Assemble

Recently your team noticed that the computer you use to practice for
programming contests is not good enough anymore. Therefore, you decide
to buy a new computer. To make the ideal computer for your needs, you
decide to buy separate components and assemble the computer yourself.
You need to buy exactly one of each type of component. The problem is
which components to buy. As you all know, the quality of a computer is
equal to the quality of its weakest component. Therefore, you want to
maximize the quality of the component with the lowest quality, while
not exceeding your budget. Input On the rst line one positive number:
the number of testcases, at most 100. After that per testcase: One
line with two integers: 1 n 1000, the number of available
components and 1 b 1000000000, your budget. n lines in the
following format: ` type name price quality ‘, where type is a string
with the type of the component, name is a string with the unique name
of the component, price is an integer (0 price 1000000) which
represents the price of the component and quality is an integer (0
quality 1000000000) which represents the quality of the component
(higher is better). The strings contain only letters, digits and
underscores and have a maximal length of 20 characters. It will always
possible to construct a computer with your budget. Output Per
testcase: One line with one integer: the maximal possible quality.

二分品质最小值,然后从所有配件中选择能选的【品质不小于二分值的】费用最小的,看是否可行。

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
#include<map>
#include<vector>
#include<iostream>
using namespace std;
const int oo=0x3f3f3f3f;
int n,m,b;
vector<pair<int,int> > v[1010];
map<string,int> mp;
void init()
{
    int i,x,y;
    string s;
    mp.clear();
    m=0;
    scanf("%d%d",&n,&b);
    for (i=1;i<=n;i++)
    {
        cin>>s;
        scanf("%*s%d%d",&x,&y);
        if (!mp.count(s))
        {
            mp[s]=++m;
            v[m].clear();
        }
        v[mp[s]].push_back(make_pair(x,y));
    }
}
bool ok(int x)
{
    int i,j,ans=0,tem;
    for (i=1;i<=m;i++)
    {
        tem=oo;
        for (j=0;j<v[i].size();j++)
          if (v[i][j].second>=x)
            tem=min(tem,v[i][j].first);
        if (tem==oo) return 0;
        ans+=tem;
    }
    return ans<=b;
}
int main()
{
    int T,l,r,mid;
    scanf("%d",&T);
    while (T--)
    {
        init();
        l=0;
        r=1000000000;
        while (l<r)
        {
            mid=(l+r+1)/2;
            if (ok(mid)) l=mid;
            else r=mid-1;
        }
        printf("%d\n",l);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值