这个是去年astar的题~

标准做法主席树,然而渣渣并不会(我确实叫zhazha。。。),

所以,他先离线,离散化,然后树状数组+二分水过了。。。。

离线的目的主要是为了离散化,剩下的就和用一个树状数组维护一个数之前有多少个数比他小差不多~~

二分答案+树状数组求和判断即可,注意二分何时终止~~(复杂度O(nlognlogn))

 #include <bits/stdc++.h>

 using namespace std;
const int maxn = + ;
int n, a[maxn], input[maxn], c[maxn];
char str[maxn][]; int flag[maxn]; map<int, int> mp; inline int lowbit(int x){
return x & (-x);
} int sum(int x){
int ret = ;
while(x > ){
ret += c[x];
x -= lowbit(x);
}
return ret;
} void add(int x, int d){
while(x <= n){
c[x] += d;
x += lowbit(x);
}
} void solve(int p){
int left = , right = n+; while(left+<right){
int mid = (left + right)/;
int sum1 = sum(mid);
//cout << "mid: " << mid << " sum: " << sum1 << endl; if( sum1 > p ){
right = mid;
}else if( sum1 < p ){
left = mid;
}else{
if(flag[mid] == ){
printf("%d\n", a[mid]);
return;
}else{
right = mid;
}
}
}
} queue<int> q; int main(void){
int cas = ;
while(scanf("%d", &n) != EOF){
int len = , num;
for(int i = ; i < n; ++i){
scanf("%s", str[i]);
if(str[i][] == 'i'){
scanf("%d", &num);
input[++len] = num;
a[len] = num;
}
} //离散化
sort(a+, a+len+);
mp.clear();
for( int i = ; i <= len; ++i ){
mp[a[i]] = i;
} memset(c, , sizeof(c));
memset(flag, , sizeof(flag)); while(!q.empty())
q.pop(); printf("Case #%d:\n", cas++);
int sz = , cnt = ;
for( int i = ; i < n; ++i ){
if( str[i][] == 'i' ){
num = input[++cnt];
q.push(num);
sz++;
num = mp[num];
add(num, );
flag[num] = ;
}else if( str[i][] == 'q' ){
int p = sz/+;
//cout << "p: " << p << endl;
solve(p);
}else{
sz--;
num = q.front();
q.pop();
num = mp[num];
add(num, -);
flag[num] = ;
}
}
} return ;
} /**
11
in 32
in 16
in 87
out
in 96
in 34
query
out
out
in 3687
query
*/

hdu5249的更多相关文章

  1. 无序数组的中位数(set+deque)hdu5249

    KPI Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  2. 划分树 poj2104 hdu5249

    KPI Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  3. hdu5249 Tricks Device(网络流最大匹配)

    分析题意可知: 1.最少须要切断多少边使吴不能找到张(题意吴仅仅能走最短路径上面的边),对从起点到终点的最短路径又一次建图,每条边的权值为1.求最大流就可以 2.在吴能够找到张的前提下,最多能够切断边 ...

  4. [hdu5249]动态中位数

    题意:3种操作分别为入队,出队,查询当前队列的中位数.操作数为1e5数量级. 思路:先考虑离线算法,可以离散+线段树,可以划分树,考虑在线算法,则有treap名次树,SBtree(size balan ...

随机推荐

  1. CSS3 background-origin 属性

    CSS3 background-origin 属性 padding-box 背景图像相对于内边距框来定位. border-box 背景图像相对于边框盒来定位. content-box 背景图像相对于内 ...

  2. 配置git使用ssh方式克隆gitlab的代码

    配置ssh key https://www.cnblogs.com/hafiz/p/8146324.html 配置host https://www.cnblogs.com/kaerxifa/p/109 ...

  3. php银联支付

    简介 PHP银联支付 流程 1.注册 银联 - 技术开发平台和商户服务平台 https://open.unionpay.com 注意:注册时建议使用IE浏览器,之前注册时插件老是用不了,使用IE10以 ...

  4. UpLoadify在IE下兼容问题

    一.在IE9.IE10不能点击的问题解决 解决方法:进入uploadify的js文件中,搜索SWFUpload.prototype.getFlashHTML,找到它对应的语句,将方法全部替换为以下内容 ...

  5. 面试bb

    1.面试者进行自我介绍 2.学校/学历/大学生活及课程的心得总结(人品,性格评估) 3.技能介绍(是否对应聘工作有帮助,评估学习能力):编程/操作系统/测试工具/测试方法/脚本 4.离职原因/项目经验 ...

  6. [工具]ps

    ps 如果想看一个进程的启动时间,可以用lstart来看 [root@jiangyi02.sqa.zmf /home/ahao.mah] #ps -eo pid,lstart,etime,cmd |g ...

  7. 使用Python的Flask框架,结合Highchart,动态渲染图表

    服务端动态渲染图表 参考文章链接:https://www.highcharts.com.cn/docs/dynamic-produce-html-page 参考文章是使用php写的,我这边改用pyth ...

  8. 非常简单的Python HTTP服务

    如果你急需一个简单的Web Server,但你又不想去下载并安装那些复杂的HTTP服务程序,比如:Apache,ISS等.那么, Python 可能帮助你.使用Python可以完成一个简单的内建 HT ...

  9. Django-cookie与session操作

    添加cookie: def login(req): if req.method=="POST": uf = UserInfoForm(req.POST) if uf.is_vali ...

  10. 【[Offer收割]编程练习赛13 B】最大子矩阵(自己的思路)

    [题目链接]:http://hihocoder.com/contest/offers13/problem/2 [题意] [题解] 算出1..250*250这些数字每个数字的所有因子(成对的那种,即x* ...