L3-002. 堆栈

时间限制
200 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

大家都知道“堆栈”是一种“先进后出”的线性结构,基本操作有“入栈”(将新元素插入栈顶)和“出栈”(将栈顶元素的值返回并从堆栈中将其删除)。现请你实现一种特殊的堆栈,它多了一种操作叫“查中值”,即返回堆栈中所有元素的中值。对于N个元素,若N是偶数,则中值定义为第N/2个最小元;若N是奇数,则中值定义为第(N+1)/2个最小元。

输入格式:

输入第一行给出正整数N(<= 105)。随后N行,每行给出一个操作指令,为下列3种指令之一:

Push key
Pop
PeekMedian

其中Push表示入栈,key是不超过105的正整数;Pop表示出栈;PeekMedian表示查中值。

输出格式:

对每个入栈指令,将key入栈,并不输出任何信息。对每个出栈或查中值的指令,在一行中打印相应的返回结果。若指令非法,就打印“Invalid”。

输入样例:

17
Pop
PeekMedian
Push 3
PeekMedian
Push 2
PeekMedian
Push 1
PeekMedian
Pop
Pop
Push 5
Push 4
PeekMedian
Pop
Pop
Pop
Pop

输出样例:

Invalid
Invalid
3
2
2
1
2
4
4
5
3
Invalid

思路:模拟堆栈+BIT

首先push,pop操作可以先用一个堆栈来存储模拟,并且需要对BIT进行更新,譬如要push一个数x,那么在BIT的第x个位置处+1,代表该位置上存有这个数,同理,pop一个数x时,在BIT的位置x处-1,消掉该数的记录。遇到查中值时即可对BIT二分搜索,譬如要查第n/2个数,若这个数数值为x,那么对BIT从1到x所有位置进行取和的值就是n/2。

AC代码:

#define _CRT_SECURE_NO_DEPRECATE
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<vector>
#include<string>
#include<iomanip>
#include<map>
#include<stack>
#include<set>
using namespace std;
#define N_MAX 100000+2
#define INF 0x3f3f3f3f
int n;
int bit[N_MAX + ]; int sum(int i) {
int s = ;
while (i>) {
s += bit[i];
i -= i&-i;
}
return s;
} void add(int i,int x) {
while (i<=N_MAX) {//!!!!!!!!
bit[i] += x;
i += i&-i;
}
} bool C(int x,int n) {
if (sum(x) >= n)return true;
else return false;
} int st[N_MAX]; int main() {
while (scanf("%d", &n) != EOF) {
memset(bit, , sizeof(bit));
int num = ;
while (n--) {
char s[]; scanf("%s",s);
if (s[] == 'o') {
if (num == ) { puts("Invalid"); continue; }
printf("%d\n", st[num-]);
add(st[num-], -);
num--;
}
else if (s[] == 'u') {
int a; scanf("%d", &a);
add(a, ); st[num++]=a;
}
else if (s[] == 'e') {
if (num == ) { puts("Invalid"); continue; }
int lb = , ub = N_MAX;//!!!
int cnt = num;
if (cnt & )cnt = (cnt + ) / ;
else cnt /= ;
while (ub - lb > ) {
int mid = (lb + ub) >> ;
if (C(mid, cnt))ub = mid;
else lb = mid;
}
printf("%d\n", ub);
}
}
}
return ;
}

最新文章

  1. 关于开发中 hosts 文件的修改
  2. php设计模式学习之观察者模式
  3. 在windows上搭建ftp服务
  4. lightoj 1021 (数位DP)
  5. VCRedist.exe静默安装方法(转)
  6. hdu 4393 Throw nails(STL之优先队列)
  7. JAVA基本的编程50称号(7-9称号)详细解释
  8. Cocoa中层(layer)坐标系的极简理解
  9. OAF--基础
  10. python 基础篇
  11. MVC WebAPI框架里设置异常返回格式统一
  12. qt裁剪
  13. Spring Boot 解决方案 - JUnit 测试
  14. CRT/LCD/VGA Information and Timing【转】
  15. AOP中Advice执行两遍的原因
  16. 阿里云构建Kafka单机集群环境
  17. 【转】【Python】Python多进程与多线程
  18. 重点:怎样正确的使用QThread类(很多详细例子的对比,注意:QThread 中所有实现的函数是被创建它的线程来调用的,不是在线程中)good
  19. 爬虫入门【11】Pyspider框架入门—使用HTML和CSS选择器下载小说
  20. mysql 内置功能 函数 date_format函数

热门文章

  1. java基础面试题:写clone()方法时,通常都有一行代码,是什么?
  2. ios swift 里面关于变量 常量 可选类型 控制流的一些心得
  3. HTML &lt;input&gt; 标签如何屏蔽浏览器的自动填写?
  4. linux中搭建公网ftp服务器
  5. nuxt.js express模板项目IIS部署
  6. Fliptile POJ - 3279 (开关问题)
  7. HDU:4417-Super Mario(离线线段树)
  8. V4L2学习(五)VIVI虚拟摄像头驱动
  9. Android开发——JVM、Dalvik以及ART的区别
  10. OpenCV学习笔记(三) 访问像素