2018.07.24 loj#107. 维护全序集(非旋treap)
传送门
就是普通平衡树,可以拿来练非旋treap" role="presentation" style="position: relative;">treaptreap的板子。
贴个代码:
#include<bits/stdc++.h>
#define N 300005
using namespace std;
typedef pair<int,int> res;
int n;
inline int read(){
int ans=0;
char ch=getchar();
while(!isdigit(ch))ch=getchar();
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans;
}
struct Treap{
int son[N][2],root,cnt,siz[N],rd[N],val[N];
inline int build(int v){siz[++cnt]=1,val[cnt]=v,rd[cnt]=rand(),son[cnt][0]=son[cnt][1]=0;return cnt;}
inline void pushup(int p){siz[p]=siz[son[p][0]]+siz[son[p][1]]+1;}
inline int merge(int a,int b){
if(!a||!b)return a+b;
if(rd[a]<rd[b]){son[a][1]=merge(son[a][1],b),pushup(a);return a;}
son[b][0]=merge(a,son[b][0]),pushup(b);return b;
}
inline res split(int p,int k){
if(!p)return res(0,0);
res tmp,ans;
if(siz[son[p][0]]>=k){tmp=split(son[p][0],k),son[p][0]=tmp.second,pushup(p),ans.first=tmp.first,ans.second=p;return ans;}
tmp=split(son[p][1],k-siz[son[p][0]]-1),son[p][1]=tmp.first,pushup(p),ans.first=p,ans.second=tmp.second;return ans;
}
inline int rank(int p,int v){
if(!p)return 0;
if(val[p]>v)return rank(son[p][0],v);
return rank(son[p][1],v)+siz[son[p][0]]+1;
}
inline int kth(int k){
res x=split(root,k),y=split(x.first,k-1);
root=merge(merge(y.first,y.second),x.second);
return val[y.second];
}
inline int find(int p,int v){
if(!p)return 0;
if(val[p]>=v)return find(son[p][0],v);
return find(son[p][1],v)+siz[son[p][0]]+1;
}
inline void ins(int v){
int k=rank(root,v);
res x=split(root,k);
int p=build(v);
root=merge(merge(x.first,p),x.second);
}
inline void del(int v){
int k=rank(root,v);
res x=split(root,k);
root=merge(split(x.first,k-1).first,x.second);
}
inline int pre(int p,int v){
if(!p)return -0x3f3f3f3f;
if(val[p]<v)return max(val[p],pre(son[p][1],v));
return pre(son[p][0],v);
}
inline int suf(int p,int v){
if(!p)return 0x3f3f3f3f;
if(val[p]>v)return min(val[p],suf(son[p][0],v));
return suf(son[p][1],v);
}
}T;
int main(){
srand(time(NULL));
n=read();
while(n--){
int op=read(),x=read();
switch(op){
case 0:{T.ins(x);break;}
case 1:{T.del(x);break;}
case 2:{printf("%d\n",T.kth(x));break;}
case 3:{printf("%d\n",T.find(T.root,x));break;}
case 4:{int tmp=T.pre(T.root,x);printf("%d\n",tmp==-0x3f3f3f3f?-1:tmp);break;}
default:{int tmp=T.suf(T.root,x);printf("%d\n",tmp==0x3f3f3f3f?-1:tmp);break;}
}
}
return 0;
}
2018.07.24 loj#107. 维护全序集(非旋treap)的更多相关文章
- LOJ#107. 维护全序集(FHQ Treap)
题面 传送门 题解 板子,没啥好说的 //minamoto #include<bits/stdc++.h> #define R register #define inline __inli ...
- loj #107. 维护全序集
#107. 维护全序集 题目描述 这是一道模板题,其数据比「普通平衡树」更强. 如未特别说明,以下所有数据均为整数. 维护一个多重集 S SS ,初始为空,有以下几种操作: 把 x xx 加入 S S ...
- China Cloud Computing Conference(2018.07.24)
时间:2018.07.24地点:北京国家会议中心
- 2018.07.06 BZOJ 1588: HNOI2002营业额统计(非旋treap)
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Description 营业额统计 Tiger最近被公司升任为营业部经理,他上 ...
- 2018.08.06 bzoj1500: [NOI2005]维修数列(非旋treap)
传送门 平衡树好题. 我仍然是用的fhqtreap,感觉速度还行. 维护也比线段树splay什么的写起来简单. %%%非旋treap大法好. 代码: #include<bits/stdc++.h ...
- 2018.08.27 rollcall(非旋treap)
描述 初始有一个空集,依次插入N个数Ai.有M次询问Bj,表示询问第Bj个数加入集合后的排名为j的数是多少 输入 第一行是两个整数N,M 接下来一行有N个整数,Ai 接下来一行有M个整数Bj,保证数据 ...
- 2018.08.05 bzoj3223: Tyvj 1729 文艺平衡树(非旋treap)
传送门 经典的平衡树问题,之前已经用splay写过一次了,今天我突发奇想,写了一发非旋treap的版本,发现挺好写的(虽然跑不过splay). 代码: #include<bits/stdc++. ...
- 非旋 treap 结构体数组版(无指针)详解,有图有真相
非旋 $treap$ (FHQ treap)的简单入门 前置技能 建议在掌握普通 treap 以及 左偏堆(也就是可并堆)食用本blog 原理 以随机数维护平衡,使树高期望为logn级别, FHQ ...
- [模板] 平衡树: Splay, 非旋Treap, 替罪羊树
简介 二叉搜索树, 可以维护一个集合/序列, 同时维护节点的 \(size\), 因此可以支持 insert(v), delete(v), kth(p,k), rank(v)等操作. 另外, prev ...
随机推荐
- 浅谈Http、TCP、UDP和 IP 的的区别
应用层:Http,超文本传输协议(HyperText Transfer Protocal):利用TCP在两台电脑(通常是Web服务器和客户端)之间传输信息的协议.客户端使用Web浏览器发起HTTP请求 ...
- 机器学习入门-K-means算法
无监督问题,我们手里没有标签 聚类:相似的东西聚在一起 难点:如何进行调参 K-means算法 需要制定k值,用来获得到底有几个簇,即几种类型 质心:均值,即向量各维取平均值 距离的度量: 欧式距离和 ...
- 列表(ul ol dl)
Title 1 2 3 1 2 3 a 1 2 b 1 2 <!DOCTYPE html> <html lang="en"> <head> &l ...
- linux控制台批量杀进程
-| cd /app/tomcat8/bin/ ./startup.sh
- ubuntu 安装搜狗输入法
from:http://blog.csdn.net/qq_21792169/article/details/53152700 最近开始学习linux 在安装输入法中遇到的一些问题,最终成功安装,也得益 ...
- linux中与Oracle有关的内核参数详解
工作当中遇到oracle运行时CPU占用率达到90%以上,调小以下参数值后恢复正常. fs.file-max = 65536 net.core.rmem_default=262144 net.core ...
- Haskell语言学习笔记(51)Comonad
Comonad class Functor w => Comonad w where extract :: w a -> a duplicate :: w a -> w (w a) ...
- C# 窗口页面卡的处理方案-异步编程委托
今天用winform做了一个小程序,主要是用于远程数据的登录采集,因为数据量非常大,到时每次点击按钮执行程序的时候界面都会出现假死状态,具体表现是无法拖动窗口,无法最小化或关闭等,只能任务管理进程结束 ...
- jQuery height()、innerHeight()、outerHeight()函数的区别详解
参考来源:http://www.jb51.net/article/84897.htm 代码示例(可复制到编辑器直接打开): <!DOCTYPE html> <html lang=&q ...
- BeanFactory 和 ApplicationContext的区别
今天在网上查资料无意中看到这一行代码 BeanFactory factory = new ClassPathXmlApplicationContext("applicationContext ...