[TJOI2010]中位数
题目描述
给定一个由N个元素组成的整数序列,现在有两种操作:
1 add a
在该序列的最后添加一个整数a,组成长度为N + 1的整数序列
2 mid 输出当前序列的中位数
中位数是指将一个序列按照从小到大排序后处在中间位置的数。(若序列长度为偶数,则指处在中间位置的两个数中较小的那个)
例1:1 2 13 14 15 16 中位数为13
例2:1 3 5 7 10 11 17 中位数为7
例3:1 1 1 2 3 中位数为1
输入输出格式
输入格式:
第一行为初始序列长度N。第二行为N个整数,表示整数序列,数字之间用空格分隔。第三行为操作数M,即要进行M次操作。下面为M行,每行输入格式如题意所述。
输出格式:
对于每个mid操作输出中位数的值
输入输出样例
6
1 2 13 14 15 16
5
add 5
add 3
mid
add 20
mid
5
13
说明
对于30%的数据,1 ≤ N ≤ 10,000,0 ≤ M ≤ 1,000
对于100%的数据,1 ≤ N ≤ 100,000,0 ≤ M ≤ 10,000
序列中整数的绝对值不超过1,000,000,000,序列中的数可能有重复
每个测试点时限1秒
思路
双堆可过;
感谢xxy大佬!
代码实现
#include<queue>
#include<cstdio>
using namespace std;
priority_queue<int>q1;
priority_queue<int,vector<int>,greater<int> >q2;
int n,m,now;
int main(){
scanf("%d",&n);
int a;
for(int i=;i<=n;i++){
scanf("%d",&a);
q2.push(a);
}
n++;
for(now=;now<n>>;now++){
q1.push(q2.top());
q2.pop();
}
scanf("%d",&m);
char ch[];
for(int i=;i<=m;i++){
scanf("%s",ch);
if(ch[]=='a'){
scanf("%d",&a);
q1.push(a);
q2.push(q1.top());
q1.pop();
n++;
}
else printf("%d\n",q1.top());
while(now<n>>){
q1.push(q2.top());
q2.pop();
now++;
}
}
return ;
}
[TJOI2010]中位数的更多相关文章
- 洛谷 P3871 [TJOI2010]中位数 解题报告
		P3871 [TJOI2010]中位数 题目描述 给定一个由N个元素组成的整数序列,现在有两种操作: 1 add a 在该序列的最后添加一个整数a,组成长度为N + 1的整数序列 2 mid 输出当前 ... 
- luoguP3871 [TJOI2010]中位数
		题目链接 luoguP3871 [TJOI2010]中位数 题解 平衡树 代码 #include<vector> #include<cstdio> #include<cs ... 
- 洛谷——P3871 [TJOI2010]中位数
		P3871 [TJOI2010]中位数 一眼秒掉,这不是splay水题吗,套模板 #include<bits/stdc++.h> #define IL inline #define N 1 ... 
- 题解 P3871 【[TJOI2010]中位数】
		orz各位大佬,题解太强了,主席树,堆,线段树,splay,还有暴力,太巨了.所以我用的是fhq treap(好像更高级).算了. 反正都是平衡树,这道题就是动态求中位数,不会做的同学可以先做弱化版P ... 
- TJOI2010中位数
		中位数 上面是题目链接. 这一题比较水. 思路非常显然. 用mid查询时,只要返回中间值就行了. 主要就是add操作. 我们肯定不能插在末尾,然后用系统快排,这样只有30分. 那么正确的操作应该是二分 ... 
- 洛谷P3871 [TJOI2010]中位数(splay)
		题目描述 给定一个由N个元素组成的整数序列,现在有两种操作: 1 add a 在该序列的最后添加一个整数a,组成长度为N + 1的整数序列 2 mid 输出当前序列的中位数 中位数是指将一个序列按照从 ... 
- [LUOGU] P3871 [TJOI2010]中位数
		题目描述 给定一个由N个元素组成的整数序列,现在有两种操作: 1 add a 在该序列的最后添加一个整数a,组成长度为N + 1的整数序列 2 mid 输出当前序列的中位数 中位数是指将一个序列按照从 ... 
- 洛谷 3871 [TJOI2010]中位数
		[题解] 平衡树模板题,不过因为可以离线,所以有别的做法.把询问倒着做,变成删掉数字.求中位数,于是可以二分+树状数组. #include<cstdio> #include<cstr ... 
- 洛谷3871 [TJOI2010]中位数  维护队列的中位数
		题目描述 给定一个由N个元素组成的整数序列,现在有两种操作: 1 add a 在该序列的最后添加一个整数a,组成长度为N + 1的整数序列 2 mid 输出当前序列的中位数 中位数是指将一个序列按照从 ... 
随机推荐
- Android中集成第三方支付
			常见的第三方支付解决方案 支付宝支付 微信支付 银联支付 Ping++统一支付平台(需要继承服务器端和客户端) 短信支付 支付宝的集成流程 相关资料链接: 支付宝支付指引流程:支付指引流程 支付宝An ... 
- 未来十年Python的前景会怎样?
			转自:一位非常优秀的Python倡导者 作者:alex链接:https://www.zhihu.com/question/22112542/answer/166053516来源:知乎著作权归作者所有. ... 
- Android拍照得到全尺寸图片并进行压缩/拍照或者图库选择 压缩后 图片 上传
			http://www.jb51.net/article/77223.htm https://www.cnblogs.com/breeze1988/p/4019510.html 
- struts2 源码地址
			http://archive.apache.org/dist/struts/ 
- 最近面试oracle 数据库的知识点
			1. Oracle跟SQL Server 2005的区别? 宏观上: 1). 最大的区别在于平台,oracle可以运行在不同的平台上,sql server只能运行在windows平台上,由于windo ... 
- webpack3整理(第一节/满三节)
			一.css文件打包到js中(loader的三种写法) //第一种写法:直接用use. module: { rules: [{ test: /\.css$/, use: ['style-loader', ... 
- php与其他一些相关工具的安装步骤分享
			现在很少花时间来专门写博客,都是把平时看到用到的东西像随笔一样记录在云笔记上. 在这儿分享一些php相关的技术安装过程: linux下编译安装php:php安装 phpunit安装过程:phpunit ... 
- 中国版 Office 365 (X-Tenant / Tango) 功能验证报告 - 1 简介
			花了点时间做了一次Office 365 X-Tenant的 POC,对过程做了记录和总结,在这里会陆续分享: (一) 简介 这次POC的系统环境是模拟一个公司的生产环境: 1. 公司总部在国外,拥有 ... 
- 前复权是从今天的价格倒推   后复权是从上市价格前推  不复权就是原始K线。
			前复权是从今天的价格倒推 后复权是从上市价格前推 不复权就是原始K线. 
- docker使用registry搭建本地私有仓库
			参考链接来自:http://blog.csdn.net/wangtaoking1/article/details/44180901/ 和Mavan的管理一样,Dockers不仅提供了一个中央仓库,同时 ... 
