内存限制:256 MiB 时间限制:1000 ms 标准输入输出
                            题目类型:传统 评测方式:文本比较
                                上传者: 匿名
 

splay模板题

屠龙宝刀点击就送

#include <cstdio>
typedef long long LL;
#define N 300500 LL data[N];
int siz[N],cnt[N],ch[N][],fa[N],root,cn,n;
inline int son(int x) {return ch[fa[x]][]==x;}
inline void pushup(int rt)
{
int l=ch[rt][],r=ch[rt][];
siz[rt]=cnt[rt]+siz[l]+siz[r];
}
inline void rotate(int x)
{
int y=fa[x],z=fa[y],b=son(x),c=son(y),a=ch[x][!b];
if(z) ch[z][c]=x;
else root=x;
fa[x]=z;
if(a) fa[a]=y;
ch[y][b]=a;
ch[x][!b]=y;
fa[y]=x;
pushup(y);
pushup(x);
}
void splay(int x,int i)
{
for(;fa[x]!=i;)
{
int y=fa[x],z=fa[y];
if(z==i) rotate(x);
else
{
if(son(x)==son(y))
{
rotate(y);
rotate(x);
}
else
{
rotate(x);
rotate(x);
}
}
}
}
void ins(int &rt,LL x)
{
if(!rt)
{
rt=++cn;
data[cn]=x;
siz[cn]=cnt[cn]=;
splay(cn,);
return;
}
if(data[rt]==x)
{
cnt[rt]++;
siz[rt]++;
splay(rt,);
return;
}
if(x<data[rt])
{
ins(ch[rt][],x);
fa[ch[rt][]]=rt;
pushup(rt);
}
else
{
ins(ch[rt][],x);
fa[ch[rt][]]=rt;
pushup(rt);
}
}
int getmn(int rt)
{
int p=rt,ans=-;
for(;p;p=ch[p][]) ans=p;
return ans;
}
void del(int rt,LL x)
{
if(data[rt]==x)
{
if(cnt[rt]>)
{
cnt[rt]--;
siz[rt]--;
}
else
{
splay(rt,);
int p=getmn(ch[rt][]);
if(p!=-)
{
splay(p,rt);
root=p;
fa[p]=;
ch[p][]=ch[rt][];
fa[ch[rt][]]=p;
}
else
{
root=ch[rt][];
fa[ch[rt][]]=;
}
}
return;
}
if(x<data[rt])
{
del(ch[rt][],x);
pushup(rt);
}
else
{
del(ch[rt][],x);
pushup(rt);
}
}
int getkth(int rt,int k)
{
int l=ch[rt][];
if(siz[l]+<=k&&k<=siz[l]+cnt[rt]) return rt;
if(siz[l]+>k) return getkth(ch[rt][],k);
else if(k>siz[l]+cnt[rt]) return getkth(ch[rt][],k-(siz[l]+cnt[rt]));
}
int get_suc(int rt,LL x)
{
int p=rt,ret=-;
for(;p;)
{
if(x>=data[p]) p=ch[p][];
else
{
ret=p;
p=ch[p][];
}
}
return ret;
}
int get_pre(int rt,LL x)
{
int p=rt,ret=-;
for(;p;)
{
if(x<=data[p]) p=ch[p][];
else
{
ret=p;
p=ch[p][];
}
}
return ret;
}
int get_pos(int rt,LL x)
{
if(data[rt]==x) return rt;
if(x<data[rt]) return get_pos(ch[rt][],x);
else return get_pos(ch[rt][],x);
}
int Main()
{
scanf("%d",&n);
for(LL opt,x,pos,flag;n--;)
{
scanf("%lld%lld",&opt,&x);
if(!opt) ins(root,x);
else if(opt==) del(root,x);
else if(opt==) printf("%lld\n",data[getkth(root,x)]);
else if(opt==) ins(root,x),pos=get_pos(root,x),splay(pos,),printf("%d\n",siz[ch[root][]]),del(root,x);
else if(opt==) pos=get_pre(root,x),pos==-?printf("-1\n"):printf("%lld\n",data[pos]);
else pos=get_suc(root,x),pos==-?printf("-1\n"):printf("%lld\n",data[pos]);
}
return ;
}
int sb=Main();
int main(int argc,char *argv[]) {;}

LibreOJ #107. 维护全序集的更多相关文章

  1. loj #107. 维护全序集

    #107. 维护全序集 题目描述 这是一道模板题,其数据比「普通平衡树」更强. 如未特别说明,以下所有数据均为整数. 维护一个多重集 S SS ,初始为空,有以下几种操作: 把 x xx 加入 S S ...

  2. 2018.07.24 loj#107. 维护全序集(非旋treap)

    传送门 就是普通平衡树,可以拿来练非旋treap" role="presentation" style="position: relative;"&g ...

  3. LOJ#107. 维护全序集(FHQ Treap)

    题面 传送门 题解 板子,没啥好说的 //minamoto #include<bits/stdc++.h> #define R register #define inline __inli ...

  4. LOJ107. 维护全序集【树状数组维护全序集】

    题目描述 这是一道模板题,其数据比「普通平衡树」更强. 如未特别说明,以下所有数据均为整数. 维护一个多重集 S ,初始为空,有以下几种操作: 把 x 加入 S 删除 S 中的一个 x,保证删除的 x ...

  5. 【GXZ的原创】平衡树性能测试

    本文作者为 GXZlegend ,转载请注明 出处 ,谢谢! 〇.序言 前些日子闲的蛋疼做了个平衡树性能测试... 主要是因为学会的平衡树越来越多,做题时却不知道写哪个... 本想结合效率和代码复杂度 ...

  6. BSA基础数据维护

    平台 BSA基础数据维护 .扇区五个字段的内容 本来值为0,经过107上计算解析,得出正常的数值.然后106上报(200050),得到回复(200051). 查看回复数据,是否有错误.比如提示104 ...

  7. LibreOJ 题解汇总

    目录 #1. A + B Problem #2. Hello, World! #3. Copycat #4. Quine #7. Input Test #100. 矩阵乘法 #101. 最大流 #10 ...

  8. Oracle 11g 物理Dataguard日常操作维护(二)

    Oracle 11g 物理Dataguard日常操作维护(二) 2017年8月25日 14:34 3.3 3.3.1 查看备库进程状态 SYS(125_7)@fpyj123> select pr ...

  9. 102. Binary Tree Level Order Traversal + 103. Binary Tree Zigzag Level Order Traversal + 107. Binary Tree Level Order Traversal II + 637. Average of Levels in Binary Tree

    ▶ 有关将一棵二叉树转化为二位表的题目,一模一样的套路出了四道题 ▶ 第 102 题,简单的转化,[ 3, 9, 20, null, null, 15, 7 ] 转为 [ [ 15, 7 ] , [ ...

随机推荐

  1. day1 java基础回顾-内省

    为什么要学内省? 开发框架时,经常需要使用java对象的属性来封装程序的数据,每次都使用反射技术完成此类操作过于麻烦,所以sun公司开发了一套API,专门用于操作java对象的属性. 内省是用于操作j ...

  2. 第3章 编写ROS程序-3

    1.订阅者程序 我们继续使用 turtlesim 作为测试平台,订阅 turtlesim_node发布的/turtle1/pose 话题. 这一话题的消息描述了海龟的位姿 (位置和朝向) .尽管目前你 ...

  3. 一、初识mybatis

    orm框架 1.配置文件(配置别名.mapper xml文件.数据库连接.事务) 2.创建SqlSessionFactory,创建SqlSession 3.创建model,创建Mapper xml文件 ...

  4. Linux系统下使用split命令分割大文件 (转载)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://snailwarrior.blog.51cto.com/680306/140531 ...

  5. c#---delegate关键字

    http://www.cnblogs.com/wenjiang/archive/2013/03/12/2954913.html 注:只看红字 在C#中,delegate是一个神奇的关键字,值得拿出来单 ...

  6. U3D Buildin shader

  7. django更换数据库时提示"django.db.utils.InternalError: (1366, "Incorrect string value: '\\xE7\\x94\\xA8\\xE6\\x88\\xB7' for column 'name' at row 1")"

    问题提出 昨天在运行django时,初始化使用的是自带的数据库,后来更换mysql数据库,数据库同步之后,打开mysql无法添加数据,插入数据时,提示django.db.utils.InternalE ...

  8. webpack4.0介绍与使用(一)

    1:webpack的基本使用: ##在网页中会引用那些静态资源: js, css, images, 字体文件和模板文件(.vue)等 ##网页总引用静态资源多了以后会有那些问题: 网页加载速度慢,因为 ...

  9. 洛谷P2939 [USACO09FEB]改造路Revamping Trails

    题意翻译 约翰一共有\(N\))个牧场.由\(M\)条布满尘埃的小径连接.小径可 以双向通行.每天早上约翰从牧场\(1\)出发到牧场\(N\)去给奶牛检查身体. 通过每条小径都需要消耗一定的时间.约翰 ...

  10. Python面向对象之单例模式

    单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某 一个类只有一个实例存在.当你希望在整个系统中,某个类只能出现一个实例时,单例对象就 能派上用场. 单例 ...