toj 3515堆的应用

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define N 110004
struct Heap{
	int da[N],size;
	void clear(){
	   size=0;
	}
	void insert(int v,int id){
		da[++size]=v;
		int tm = size;
		while(tm>1){
			if(id){
				if(da[tm]>da[tm/2]){
					swap(da[tm],da[tm/2]);
				}
				else{
					break;
				}
			}else{
				if(da[tm]<da[tm/2]){
					swap(da[tm],da[tm/2]);
				}else{
					break;
				}
			}
			tm/=2;
		}
	}
	void update(int id,int cur){
		int mx = cur;
		if(id){
			if(2*cur<=size && da[2*cur]>da[mx]){
				mx = cur*2;
			}
			if(2*cur+1<=size&&da[2*cur+1]>da[mx]){
				mx=cur*2+1;
			}
		}else{
			if(2*cur<=size && da[2*cur]<da[mx]){
				mx = cur*2;
			}
			if(2*cur+1<=size&&da[2*cur+1]<da[mx]){
				mx = cur*2+1;
			}
		}
		if(mx!=cur){
			swap(da[cur],da[mx]);
			update(id,mx);
		}
	}
	int gettop(int id){
		int tm = da[1];
		if(size==1){
			size=0;
			return tm;
		}
		da[1]=da[size--];
		update(id,1);
		return tm;
	}
}h[2];
void add(int v){
	if(h[1].size==0){
		h[1].insert(v,1);
		return;
	}
	else if(h[0].size==0){
		if(v<h[1].da[1]){
			int tm = h[1].gettop(1);
			h[1].insert(v,1);
			v = tm;
		}
		h[0].insert(v,0);
		return;
	}
	int tm=h[1].da[1],tp=h[0].da[1];
	if(h[1].size>h[0].size){
		if(v<tm){
			h[1].gettop(1);
		    h[1].insert(v,1);
		    h[0].insert(tm,0);
		}
		else{
			h[0].insert(v,0);
		}
	}else{
		if(v>tp){
			h[0].gettop(0);
		    h[0].insert(v,0);
		    h[1].insert(tp,1);
		}else{
				h[1].insert(v,1);
		}
	}
}
int mid(){
	return h[1].da[1];
}
int main(){
	char p[5];
	int T,n,m,i,j;
	scanf("%d",&T);
	while(T--){
		scanf("%d",&n);
		h[0].clear(),h[1].clear();
		for(i=0;i<n;i++){
			scanf("%d",&j);
			add(j); 
		}
		scanf("%d",&m);
		while(m--){
			scanf("%s",p);
			if(p[0]=='a'){
				scanf("%d",&j);
				add(j);
			}
			else{
				printf("%d\n",mid());
			}
		} 
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值