POJ 2010 Moo University - Financial Aid treap
按第一关键字排序后枚举中位数,就变成了判断“左边前K小的和 + 这个中位数 + 右边前K小的和 <= F",其中维护前K小和可以用treap做到。
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <vector>
#include <algorithm>
using namespace std; struct node
{
node *ch[];
int sz;
int v;
int r;
int sum;
node(int v = ) : v(v)
{
r = rand();
sz = ;
ch[] = ch[] = NULL;
sum = v;
}
int cmp(int k)
{
return k > v;
}
void maintain()
{
sz = ;
sum = v;
if(ch[] != NULL)
{
sz += ch[]->sz;
sum += ch[]->sum;
}
if(ch[] != NULL)
{
sz += ch[]->sz;
sum += ch[]->sum;
}
}
}; void rotate(node *&o, int d)
{
node *k = o->ch[d^];
o->ch[d^] = k->ch[d];
k->ch[d] = o;
o->maintain();
k->maintain();
o = k;
} void insert(node *&o, int v)
{
if(o == NULL) o = new node(v);
else
{
int d = o->cmp(v);
insert(o->ch[d], v);
if(o->ch[d]->r > o->r) rotate(o, d^);
}
o->maintain();
} void remove(node *&o, int v)
{
if(v == o->v)
{
if(o->ch[] == NULL) o = o->ch[];
else if(o->ch[] == NULL) o = o->ch[];
else
{
int d = o->ch[]->r < o->ch[]->r ? : ;
rotate(o, d);
remove(o->ch[d], v);
}
} else
{
int d = o->cmp(v);
remove(o->ch[d], v);
}
if(o != NULL) o->maintain();
} int query(node *o, int k)
{
int s = o->ch[] == NULL ? : o->ch[]->sz;
int sum = o->ch[] == NULL ? : o->ch[]->sum;
if(s + > k) return query(o->ch[], k);
if(s + == k) return sum + o->v;
if(s + < k) return sum + o->v + query(o->ch[], k - s - );
} void del(node *o)
{
if(o->ch[] != NULL) del(o->ch[]);
if(o->ch[] != NULL) del(o->ch[]);
delete o;
} int main()
{
int n, c, f;
while(scanf("%d%d%d", &n, &c, &f) != EOF)
{
vector<pair<int, int> > a;
for(int i = ; i < c; i++)
{
int x, y;
scanf("%d%d", &x, &y);
a.push_back(make_pair(x, y));
} sort(a.begin(), a.end()); node *r = NULL, *l = NULL;
for(int i = ; i < n / ; i++)
insert(r, a[c - i - ].second);
for(int i = c - n / - ; i >= ; i--)
insert(l, a[i].second);
int ans = -;
for(int i = c - n / - ; i >= n / ; i--)
{
remove(l, a[i].second);
if(query(l, n / ) + query(r, n / ) + a[i].second <= f)
{
ans = a[i].first;
break;
}
insert(r, a[i].second);
} printf("%d\n", ans);
del(l); del(r);
}
return ;
}
POJ 2010 Moo University - Financial Aid treap的更多相关文章
- POJ 2010 Moo University - Financial Aid( 优先队列+二分查找)
POJ 2010 Moo University - Financial Aid 题目大意,从C头申请读书的牛中选出N头,这N头牛的需要的额外学费之和不能超过F,并且要使得这N头牛的中位数最大.若不存在 ...
- poj 2010 Moo University - Financial Aid
Moo Univ ...
- poj 2010 Moo University - Financial Aid 最大化中位数 二分搜索 以后需要慢慢体会
Moo University - Financial Aid Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 6599 A ...
- poj 2010 Moo University - Financial Aid(优先队列(最小堆)+ 贪心 + 枚举)
Description Bessie noted that although humans have many universities they can attend, cows have none ...
- poj -2010 Moo University - Financial Aid (优先队列)
http://poj.org/problem?id=2010 "Moo U"大学有一种非常严格的入学考试(CSAT) ,每头小牛都会有一个得分.然而,"Moo U&quo ...
- POJ 2010 - Moo University - Financial Aid 初探数据结构 二叉堆
考虑到数据结构短板严重,从计算几何换换口味= = 二叉堆 简介 堆总保持每个节点小于(大于)父亲节点.这样的堆被称作大根堆(小根堆). 顾名思义,大根堆的数根是堆内的最大元素. 堆的意义在于能快速O( ...
- poj 2010 Moo University - Financial Aid (贪心+线段树)
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 骗一下访问量.... 题意大概是:从c个中选出n个 ...
- POJ 2010 Moo University - Financial Aid 优先队列
题意:给你c头牛,并给出每头牛的分数和花费,要求你找出其中n(n为奇数)头牛,并使这n头牛的分数的中位数尽可能大,同时这n头牛的总花费不能超过f,否则输出-1. 思路:首先对n头牛按分数进行排序,然后 ...
- POJ 2010 Moo University - Financial Aid (优先队列)
题意:从C头奶牛中招收N(奇数)头.它们分别得分score_i,需要资助学费aid_i.希望新生所需资助不超过F,同时得分中位数最高.求此中位数. 思路: 先将奶牛排序,考虑每个奶牛作为中位数时,比它 ...
随机推荐
- 监听JVM的几个命令(可用于linux 本机)
1. jstat 这个命令对于查看Jvm的堆栈信息很有用.能够查看eden,survivor,old,perm等heap的capacity,utility信息 对于查看系统是不是有能存泄漏以及参数设置 ...
- Spring异常抛出触发事务回滚
Spring.EJB的声明式事务默认情况下都是在抛出unchecked exception后才会触发事务的回滚 /** * 如果在spring事务配置中不为切入点(如这里的切入点可以定义成test*) ...
- JS函数
1.document.write(""); 输出语句2.JS中的注释为//3.传统的HTML文档顺序是:document->html->(head,body)4.一个浏 ...
- phpstorm 16.1 注册码
phpstorm 2016.1 的注册与phpstorm 10 相同,可以采用:“服务器注册” 方式进行注册,又快又方便. 服务器注册:http://idea.qinxi1992.cn IDEA 20 ...
- highcharts 柱状图 动态加载
highcharts柱状图动态加载 (1):导入样式 <script type="text/javascript" src="<%=request.getCo ...
- CSS 中文字体的英文名称 (simhei, simsun) 宋体 微软雅黑
华文细黑:STHeiti Light [STXihei] 华文黑体:STHeiti 华文楷体:STKaiti 华文宋体:STSong 华文仿宋:STFangsong 俪黑 Pro:LiHei Pr ...
- 机器学习PR:k近邻法分类
k近邻法是一种基本分类与回归方法.本章只讨论k近邻分类,回归方法将在随后专题中进行. 它可以进行多类分类,分类时根据在样本集合中其k个最近邻点的类别,通过多数表决等方式进行预测,因此不具有显式的学习过 ...
- javascript算法
代码运行环境: nodejs + mochajs /* *选择排序 *每次查找数组最小数据 *将最小数据排到左侧 */ var assert = require('assert'); describe ...
- 路由器TL-WR941N V5.1:救砖、MOD
完成效果图: --- 拆芯片时需要贴上胶带,防止误伤: --- 堆锡拆除旧的flash芯片: --- 购入物品: --- 编程器刷入Breed: --- Web刷机: --- 预处理材料: --- 7 ...
- 有关emoji表情以及utf-16编码
昨日IOS组的同事遇到一个棘手的问题:当输入框内含有emoji表情时,如何获取文本框内的字符数(一个emoji表情算一个字符). 先从我最近接触的JAVA说起,JAVA中,在使用S ...