[luogu]P1168 中位数[堆]
中位数
题目描述
给出一个长度为N的非负整数序列A[i],对于所有1 ≤ k ≤ (N + 1) / 2,输出A[1], A[3], …, A[2k - 1]的中位数。即前1,3,5,……个数的中位数。
输入输出格式
输入格式:
输入文件median.in的第1行为一个正整数N,表示了序列长度。
第2行包含N个非负整数A[i] (A[i] ≤ 10^9)。
输出格式:
输出文件median.out包含(N + 1) / 2行,第i行为A[1], A[3], …, A[2i – 1]的中位数。
输入输出样例
输入样例1#:
7
1 3 5 7 9 11 6
输出样例1#:
1
3
5
6
【数据范围】
对于20%的数据,N ≤ 100;
对于40%的数据,N ≤ 3000;
对于100%的数据,N ≤ 100000。
好尴尬,一开始理解错题意,把序列排序就输出来了,感觉好傻...
维护两个堆,一个大根堆,一个小根堆,小根堆的最小元素比大根堆的最大元素大,每加进一个元素,如果比大根堆的最大元素小,加到前面的大根堆,否则加到后面的小根堆。
调整大根堆的大小使其为(i+1)/2。
c++的话用STL非常方便。
代码:
 #include<iostream>
 #include<cstdio>
 #include<cstring>
 #include<queue>
 using namespace std;
 inline int read();
  ;
 priority_queue< int > a;
 priority_queue< int > b;
 int n;
 namespace lys{
     int main(){
         int i,x,y;
         n=read();
         ;i<=n;i++){
             x=read();
             if(a.empty()) a.push(x);
             else{
                 if(x<=a.top()) a.push(x);
                 else b.push(-x);
             }
             )>>)){
                 x=b.top();
                 b.pop();
                 a.push(-x);
             }
             )>>)){
                 x=-a.top();
                 a.pop();
                 b.push(x);
             }
             ){
                 x=a.top();
                 printf("%d\n",x);
             }
         }
         ;
     }
 }
 int main(){
     lys::main();
     ;
 }
 inline int read(){
     ,f=;
     char c=getchar();
     '){
         if(c=='-')
             f=-;
         c=getchar();
     }
     '){
         k=k*+c-';
         c=getchar();
     }
     return k*f;
 }
[luogu]P1168 中位数[堆]的更多相关文章
- LuoGu P1168 中位数
		题目描述 给出一个长度为 $ N $ 的非负整数序列 $ A_i $ ,对于所有 $ 1 ≤ k ≤ (N + 1) / 2 $ ,输出 $ A_1, A_3, -, A_{2k - 1} $ 的中位 ... 
- P1168 中位数[堆 优先队列]
		题目描述 给出一个长度为NNN的非负整数序列AiA_iAi,对于所有1≤k≤(N+1)/21 ≤ k ≤ (N + 1) / 21≤k≤(N+1)/2,输出A1,A3,…,A2k−1A_1, A_3 ... 
- P1168 中位数    堆
		题目描述 给出一个长度为NN的非负整数序列A_iAi,对于所有1 ≤ k ≤ (N + 1) / 21≤k≤(N+1)/2,输出A_1, A_3, …, A_{2k - 1}A1,A3,…,A2 ... 
- luogu P1168 中位数 |树状数组+二分
		题目描述 给出一个长度为NN的非负整数序列A_i,对于所有1 ≤ k ≤ (N + 1) / 21≤k≤(N+1)/2,输出A_1, A_3, -, A_2k - 1的中位数.即前1,3,5,-个数的 ... 
- 【Luogu P1168】【Luogu P1801&UVA 501】中位数&黑匣子(Black Box)——对顶堆相关
		Luogu P1168 Luogu P1801 UVA 501(洛谷Remote Judge) 前置知识:堆.优先队列STL的使用 对顶堆 是一种在线维护第\(k\)小的算法. 其实就是开两个堆,一个 ... 
- 洛谷——P1168 中位数
		P1168 中位数 题目描述 给出一个长度为NN的非负整数序列$A_i$,对于所有1 ≤ k ≤ (N + 1),输出$A_1, A_3, …, A_{2k - 1}A1,A3,…,A2k−1 ... 
- P1168 中位数
		P1168 中位数树状数组+二分答案.树状数组就是起一个高效查询比二分出来的数小的有几个. #include<iostream> #include<cstdio> #inclu ... 
- Luogu P1627 中位数
		Luogu P1627 中位数 先记录目标数的位置,并且把数组映射为: $$a[i]=\begin{cases}-1,a[i]<b\0,a[i]=b\1,a[i]>b\end{cases} ... 
- 【洛谷】【堆】P1168 中位数
		[题目描述:] 给出一个长度为N的非负整数序列A[i],对于所有1 ≤ k ≤ (N + 1) / 2,输出A[1], A[3], …, A[2k - 1]的中位数.即前1,3,5,……个数的中位数. ... 
随机推荐
- Fiddler代理抓取的接口的服务器返回出现"Response body is encoded. Click to decode. "
			参考与:https://blog.csdn.net/wsbl52006/article/details/53256705 解决办法: Rules > Remove All Encodings 勾 ... 
- 【ABAP系列】SAP ABAP的事件执行顺序
			公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP的事件执行顺序 ... 
- python列表-使用
			一.列表用于循环 1.for循环 2. in 和 not in 3.多重赋值 
- 一次特殊的“VARCHAR转numeric失败”错误记录
			今天接触到一个很有意思的问题.当我在执行一条INSERT的sql语句时,他总是报字符串转数字类型失败. 问题 首先,该表中的所有数字类型的字段都是非必填,其次,每个数字类型的字段都有默认值.最令我感到 ... 
- Atman开发实习生的笔试题
			坐标:山东 编程题(限时30分钟)如何判断一个字符串是否为合法的IP地址.要求:1. 不能使用正则表达式和自带的库函数.2. 列出全部测试用例,并给出原因.3. 把代码的后缀名改成txt后上传,不用压 ... 
- APMServ升级PHP至5.3
			APMServ5.2.6 的php版本是php5.2.6,所以需要升级一下PHP版本:1.到 php下载地址下载PHP5.3的VC6版本的zip文件,我下载的是:php-5.3.23-Win32-VC ... 
- 什么是 Python 的命名空间?
			在 Python 中,所有的名字都存在于一个空间中,它们在该空间中存在和被操作——这就是命名空间.它就好像一个盒子,每一个变量名字都对应装着一个对象.当查询变量的时候,会从该盒子里面寻找相应的对象. 
- 2019牛客暑期多校训练营(第三场) - J - LRU management - 模拟
			https://ac.nowcoder.com/acm/contest/883/J 根据这个数据结构的特点,也就是计算机组成原理里面学过的cache的LRU管理算法,每次访问都会在cache中查询一页 ... 
- python实现一个简单的网络聊天程序
			一.Linux Socket 1.Linux Socke基本上就是BSD Socket(伯克利套接字) 伯克利套接字的应用编程接口(API)是采用C语言的进程间通信的库,经常用在计算机网络间的通信.B ... 
- python学习笔记(7): 面向对象
			class Foo: #类中的函数 def bar(self): #功能阐述 print('Bar') pass def hello(self,name): print('i am %s' %name ... 
