您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:
1. 插入x数
2. 删除x数(若有多个相同的数,因只删除一个)
3. 查询x数的排名(若有多个相同的数,因输出最小的排名)
4. 查询排名为x的数
5. 求x的前驱(前驱定义为小于x,且最大的数)
6. 求x的后继(后继定义为大于x,且最小的数)

Input

第一行为n,表示操作的个数,下面n行每行有两个数opt和x,opt表示操作的序号(1<=opt<=6)

Output

对于操作3,4,5,6每行输出一个数,表示对应答案

Sample Input10
1 106465
4 1
1 317721
1 460929
1 644985
1 84185
1 89851
6 81968
1 492737
5 493598

Sample Output106465
84185
492737
Hint

1.n的数据范围:n<=100000
2.每个数的数据范围:[-2e9,2e9]
 
不多说了,模板练习。
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
using namespace std;
const int maxn=;
struct Splay{
int ch[maxn][],fa[maxn],num[maxn],sz[maxn],key[maxn],rt,cnt;
int get(int x) { return ch[fa[x]][]==x;}
Splay(){ rt=cnt=; }
void update(int Now)
{
if(!Now) return ;
sz[Now]=num[Now];
if(ch[Now][]) sz[Now]+=sz[ch[Now][]];
if(ch[Now][]) sz[Now]+=sz[ch[Now][]];
}
void rotate(int x)
{
int old=fa[x],fold=fa[old],opt=(ch[old][]==x);
fa[ch[x][opt^]]=old; ch[old][opt]=ch[x][opt^];
ch[x][opt^]=old; fa[old]=x; fa[x]=fold;
if(fold) ch[fold][ch[fold][]==old]=x;
else rt=x;
update(old); update(x);
}
void splay(int x,int y)
{
for(int f;(f=fa[x])!=y;rotate(x)){
if(fa[f]!=y)
rotate(get(x)==get(f)?f:x);
}
if(!y) rt=x;
}
void insert(int x)
{
if(!rt){
rt=++cnt; key[cnt]=x; sz[cnt]=num[cnt]=; return ;
}
int Now=rt,f=;
while(true){
if(key[Now]==x){
num[Now]++; update(Now); update(f); splay(Now,); return;
}
f=Now; Now=ch[Now][key[Now]<x];
if(!Now) {
fa[++cnt]=f; ch[f][key[f]<x]=cnt; num[cnt]=sz[cnt]=;
key[cnt]=x; update(f); splay(cnt,); return ;
}
}
}
void del(int x)
{
int whatever=find(x);
if(num[rt]>){num[rt]--; update(rt); return;}
if(!ch[rt][]&&!ch[rt][]) { rt=; return;}
if(!ch[rt][]){
int oldroot=rt; rt=ch[rt][]; fa[rt]=; return;
}
else if (!ch[rt][]){
int oldroot=rt; rt=ch[rt][]; fa[rt]=; return;
}
int leftbig=pre(),oldroot=rt;
splay(leftbig,);
ch[rt][]=ch[oldroot][];
fa[ch[oldroot][]]=rt;
update(rt);
}
int find(int x)
{
int Now=rt,res=;
while(true){
if(x<key[Now]) Now=ch[Now][];
else {
res+=ch[Now][]?sz[ch[Now][]]:;
if(key[Now]==x) {
splay(Now,);return res+;
}
res+=num[Now]; Now=ch[Now][];
}
}
}
int findx(int x)
{
int Now=rt;
while(true){
if(ch[Now][]&&sz[ch[Now][]]>=x) Now=ch[Now][];
else {
if(ch[Now][]) x-=sz[ch[Now][]];
if(num[Now]>=x) return key[Now];
x-=num[Now];
Now=ch[Now][];
}
}
}
int pre()
{
int Now=ch[rt][];
while(ch[Now][]) Now=ch[Now][];
return Now;
}
int nxt()
{
int Now=ch[rt][];
while(ch[Now][]) Now=ch[Now][];
return Now;
}
}S;
int main()
{
int N,opt,x;
scanf("%d",&N);
while(N--){
scanf("%d%d",&opt,&x);
switch(opt){
case : S.insert(x); break;
case : S.del(x); break;
case : printf("%d\n",S.find(x)); break;
case : printf("%d\n",S.findx(x)); break;
case : S.insert(x); printf("%d\n",S.key[S.pre()]); S.del(x);break;
case : S.insert(x); printf("%d\n",S.key[S.nxt()]); S.del(x);break;
}
}
return ;
}

BZOJ3224:普通平衡树(splay练习)的更多相关文章

  1. bzoj3224 普通平衡树(splay 模板)

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 11427  Solved: 4878[Submit][St ...

  2. BZOJ3224:普通平衡树(Splay)

    Description 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作: 1. 插入x数 2. 删除x数(若有多个相同的数,因只删除一个) 3. 查询x数的排名(若有多个相 ...

  3. [luogu3369/bzoj3224]普通平衡树(splay模板、平衡树初探)

    解题关键:splay模板题整理. 如何不加入极大极小值?(待思考) #include<cstdio> #include<cstring> #include<algorit ...

  4. bzoj3224 普通平衡树 splay模板

    题目传送门 题目大意:完成一颗splay树. 思路:模板题,学着还是很有意思的. 学习splay树:蒟蒻yyb 该题模板:汪立超 #include<bits/stdc++.h> #defi ...

  5. 【BZOJ3224】Tyvj 1728 普通平衡树 Splay

    Description 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3. 查询x数的排名(若有多个相同的数 ...

  6. BZOJ3224/洛谷P3391 - 普通平衡树(Splay)

    BZOJ链接 洛谷链接 题意简述 模板题啦~ 代码 //普通平衡树(Splay) #include <cstdio> int const N=1e5+10; int rt,ndCnt; i ...

  7. 【转】 史上最详尽的平衡树(splay)讲解与模板(非指针版spaly)

    ORZ原创Clove学姐: 变量声明:f[i]表示i的父结点,ch[i][0]表示i的左儿子,ch[i][1]表示i的右儿子,key[i]表示i的关键字(即结点i代表的那个数字),cnt[i]表示i结 ...

  8. hiho #1329 : 平衡树·Splay

    #1329 : 平衡树·Splay 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,上一次你跟我讲了Treap,我也实现了.但是我遇到了一个关键的问题. ...

  9. Hihocoder 1329 平衡树·Splay(平衡树)

    Hihocoder 1329 平衡树·Splay(平衡树) Description 小Ho:小Hi,上一次你跟我讲了Treap,我也实现了.但是我遇到了一个关键的问题. 小Hi:怎么了? 小Ho:小H ...

  10. 【阶梯报告】洛谷P3391【模板】文艺平衡树 splay

    [阶梯报告]洛谷P3391[模板]文艺平衡树 splay 题目链接在这里[链接](https://www.luogu.org/problemnew/show/P3391)最近在学习splay,终于做对 ...

随机推荐

  1. [Vijos1512] SuperBrother打鼹鼠 (二维树状数组)

    传送门 直接搞就行. 注意下表re从零开始,而树状数组搞不了0,所以统一增加一个偏移量1. (话说数据随机是什么鬼?) # include <iostream> # include < ...

  2. 【dp】codeforces C. Vladik and Memorable Trip

    http://codeforces.com/contest/811/problem/C [题意] 给定一个自然数序列,在这个序列中找出几个不相交段,使得每个段的异或值之和相加最大. 段的异或值这样定义 ...

  3. hdu 4045 Machine scheduling [ dp + 斯特林数]

    传送门 Machine scheduling Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/O ...

  4. poj——3177Redundant Paths

    poj——3177Redundant Paths      洛谷—— P2860 [USACO06JAN]冗余路径Redundant Paths Time Limit: 1000MS   Memory ...

  5. 转 常见hash算法的原理

    散列表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法.顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙. 散列表(Hash table,也叫 ...

  6. C# 读自己的资源文件

    Assembly assm = this.GetType().Assembly;//Assembly.LoadFrom(程序集路径); foreach (string resName in assm. ...

  7. 火狐firefox、谷歌chrome等浏览器扩展、插件介绍

    火狐旧的插件扩展已经不可用,需要更新,这是本人安装的最新的插件 chrome插件 https://www.zhihu.com/question/68338297

  8. N+6 裁员裁出幸福感的背后

    01. 史上最牛逼的数据库公司,Oracle 裁员了. 2019年5月7日,甲骨文召开了面向全中国区的电话会议,亚太区人力资源负责人在会上简要介绍道,公司正进行业务结构调整,导致一部分人要离开岗位,这 ...

  9. IOS开发 序列化与反序列化

    原帖地址:http://blog.csdn.net/ally_ideveloper/article/details/7956942 不会用,记下自己有时间看 序列化与反序列化概述 序列化,它又称串行化 ...

  10. 【python】super()

    转自: http://www.cnblogs.com/lovemo1314/archive/2011/05/03/2035005.html