POJ - 2010 Moo University - Financial Aid 贪心+优先队列

来源:互联网 发布:js中怎么删除数组元素 编辑:程序博客网 时间:2024/06/06 07:45

题目大意:有C头牛,每头牛都有相应的分数和需求,要求在这C头牛中选出N头,使得这N头牛中的分数的中位数达到最大,且需求之和小于等于F

解题思路:先按成绩排序
再用两个数组保留最小需求之和
left数组保留第i个位置左边的 N/2个最小需求之和
right数组保留第i个位置右边的 N/2个最小需求之和
如何保留最小的需求之和呢,扫描两遍(左右),用优先队列保留N / 2个最小需求
最后只需要判断一下 left[i] + right[i] + 第i头牛的需求 <= F就可以了

#include<cstdio>#include<cstring>#include<algorithm>#include<queue>using namespace std;#define maxn 100010typedef long long ll;struct Cows{    ll score, aid;}cow[maxn];int N, C;ll F, left[maxn], right[maxn];bool cmp(const Cows a, const Cows b) {    return a.score < b.score;}void solve() {    sort(cow, cow + C, cmp);    for(int i = 0; i < C; i++)        left[i] = right[i] = 0;    priority_queue<ll> pq;    ll sum1 = 0;    for(int i = 0; i < C; i++) {        if(i < N / 2) {            pq.push(cow[i].aid);            sum1 += cow[i].aid;            continue;        }        left[i] = sum1;        if(cow[i].aid >= pq.top())            continue;        sum1 -= pq.top();        pq.pop();        sum1 += cow[i].aid;        pq.push(cow[i].aid);    }    while(!pq.empty())        pq.pop();    sum1 = 0;    for(int i = C - 1; i >= 0; i--) {        if(i > C - 1 - N / 2) {            sum1 += cow[i].aid;            pq.push(cow[i].aid);            continue;        }        right[i] = sum1;        if(cow[i].aid >= pq.top())            continue;        sum1 -= pq.top();        pq.pop();        sum1 += cow[i].aid;        pq.push(cow[i].aid);    }    ll ans = -1;    for(int i = N / 2; i <= C - 1 - N / 2; i++)        if(left[i] + right[i] + cow[i].aid <= F)             ans = cow[i].score;    printf("%lld\n", ans);}int main(){    while(scanf("%d%d%lld",&N, &C, &F) != EOF) {        for(int i = 0; i < C; i++)            scanf("%lld%lld", &cow[i].score, &cow[i].aid);        solve();    }    return 0;}
0 1
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 联通忘了宽带的用户名和密码怎么办 宽带联通移机附近没有端口怎么办 电信卡怎么改服务密码忘记了怎么办 路由器重置宽带账号密码忘了怎么办 重置路由器后不知道宽带密码怎么办 欠费后重新缴费宽带连接不了怎么办 华硕路由器忘记账号密码忘了怎么办 光纤猫光信号闪红灯不能上网怎么办 被传销洗了脑的人怎么办 辞职了评职称年度考核表怎么办 我是饭店饭店欠供货商的钱多怎么办 mac电脑ps卡住了点不了怎么办 高考自愿民族栏要改为民族怎么办 法院拆消裁定后再审有错怎么办 重定向语句前面有文件路劲怎么办 您上传的图片大小超过3M怎么办 两个人打架被拍视频上传了怎么办 小米手机打开后一直出现英文怎么办 百度云分享文件含有违规内容怎么办 百度网盘下载说本地空间不足怎么办 绘声绘影X9将滤镜拖到视频怎么办 苹果手机中间的按钮没用了怎么办? 图片怎么发的在百度里面应该怎么办 学java刚看的视频就忘了怎么办 qq上传照片一直显示排队中怎么办 微信支付不小心重复付款怎么办 学习通上传视频时 文件过大怎么办 电脑死机了怎么办 也不能关机了 还没发货淘宝退款卖家不处理怎么办 还没发货申请退款卖家不处理怎么办 快递写错电话被更改收货信息怎么办 货在派送中快递地址填错了怎么办 老板损坏了你保管的器材怎么办 闲鱼买家说不合适要退货怎么办 日本邮便局的单号我忘了怎么办 小米盒子自带播放器被删除了怎么办 在电视上装了央视影音要升级怎么办 用现金支付货款没有了证据怎么办 楚楚街不发货客服不理人怎么办 厨房那面墙借用别人的怎么办 天猫买东西商家不给发货怎么办