【模板】 非旋转treap
模板:luogu P3369 【模板】普通平衡树
code:
#include <cstdio>
#include <cstdlib>
const int MAX_N=100010;
int rd() {
int x=0,fla=1; char c=' ';
while(c<'0' or c>'9') {c=getchar();if(c=='-') fla=-fla;}
while(c>='0' and c<='9') x=x*10+c-'0',c=getchar();
return x*fla;
}
struct node{
node *ch[2]; int data,key,size;
node () {}
node(int w,node *son) {ch[0]=ch[1]=son, data=w, key=rand(), size=1;}
void updata () {size = ch[0]->size + ch[1]->size +1;}
}nil,t[MAX_N],*null,*len,*root;;
void init() {
nil=node(0,NULL); null= &nil;
null->ch[0]=null->ch[1]=null;
null->size=0; len=t; root=null;
}
node* newnode(int x) {
*len=node(x,null);
return len++;
}
node* merge(node* a,node* b) {
if(a==null or b==null) return a==null?b:a;
if(a->key > b->key) {a->ch[1]=merge(a->ch[1],b); a->updata(); return a;}
else {b->ch[0]=merge(a,b->ch[0]); b->updata(); return b;}
}
void split(node* x,int k,node* &l,node* &r) {
if(x==null) {l=r=null;return ;}
if(x->data <= k) {l=x; split(l->ch[1],k,l->ch[1],r);}
else {r=x; split(r->ch[0],k,l,r->ch[0]);}
x->updata();
}
void insert(int k) {
node *l,*r; split(root,k,l,r);
root=merge(merge(l,newnode(k)),r);
}
void erase(int k) {
node *l,*mid,*r; split(root,k-1,l,r); split(r,k,mid,r);
root=merge(l,merge(merge(mid->ch[0],mid->ch[1]) ,r));
}
int kth(node *x,int k) {
if(k <= x->ch[0]->size) return kth(x->ch[0],k);
else if(k > x->ch[0]->size+1) return kth(x->ch[1],k - x->ch[0]->size-1);
return x->data;
}
int find(node *x,int d) {
while(x->ch[d]!=null) x=x->ch[d];
return x->data;
}
int main() {
init(); int q=rd(),c; node *l,*r;
while(q--)
switch(c=rd()) {
case 1:insert(rd());break;
case 2:erase(rd());break;
case 3:split(root,rd()-1,l,r);printf("%d\n",l->size+1);root=merge(l,r);break;
case 4:printf("%d\n",kth(root,rd()));break;
case 5:split(root,rd()-1,l,r);printf("%d\n",find(l,1));root=merge(l,r);break;
case 6:split(root,rd(),l,r);printf("%d\n",find(r,0));root=merge(l,r);break;
}
return 0;
}
【模板】 非旋转treap的更多相关文章
- BZOJ5063旅游——非旋转treap
题目描述 小奇成功打开了大科学家的电脑. 大科学家打算前往n处景点旅游,他用一个序列来维护它们之间的顺序.初 始时,序列为1,2,...,n. 接着,大科学家进行m次操作来打乱顺序.每次操作有6步: ...
- BZOJ1251序列终结者——非旋转treap
题目描述 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技 ...
- 平衡树及笛卡尔树讲解(旋转treap,非旋转treap,splay,替罪羊树及可持久化)
在刷了许多道平衡树的题之后,对平衡树有了较为深入的理解,在这里和大家分享一下,希望对大家学习平衡树能有帮助. 平衡树有好多种,比如treap,splay,红黑树,STL中的set.在这里只介绍几种常用 ...
- 旋转/非旋转treap的简单操作
treap(树堆) 是在二叉搜索树的基础上,通过维护随机附加域,使其满足堆性质,从而使树相对平衡的二叉树: 为什么可以这样呢? 因为在维护堆的时候可以同时保证搜索树的性质: (比如当一棵树的一个域满足 ...
- 非旋转 treap
其实之前学过一次非旋转 treap,但是全忘光了,今天复习一下. 洛谷 P3369 [模板]普通平衡树 code: #include <bits/stdc++.h> #define N 1 ...
- [bzoj3173]最长上升子序列_非旋转Treap
最长上升子序列 bzoj-3173 题目大意:有1-n,n个数,第i次操作是将i加入到原有序列中制定的位置,后查询当前序列中最长上升子序列长度. 注释:1<=n<=10,000,开始序列为 ...
- 关于非旋转treap的学习
非旋转treap的操作基于split和merge操作,其余操作和普通平衡树一样,复杂度保证方式与旋转treap差不多,都是基于一个随机的参数,这样构出的树树高为\(logn\) split 作用:将原 ...
- [Codeforces702F]T-Shirts——非旋转treap+贪心
题目链接: Codeforces702F 题目大意:有$n$种T恤,每种有一个价格$c_{i}$和品质$q_{i}$且每种数量无限.现在有$m$个人,第$i$个人有$v_{i}$元,每人每次会买他能买 ...
- BZOJ3223文艺平衡树——非旋转treap
此为平衡树系列第二道:文艺平衡树您需要写一种数据结构,来维护一个有序数列,其中需要提供以下操作: 翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 4 1 ...
- BZOJ3224普通平衡树——非旋转treap
题目: 此为平衡树系列第一道:普通平衡树您需要写一种数据结构,来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3. 查询x数的排名(若有多个相同的数, ...
随机推荐
- IPC总结学习
写的不错. http://www.cnblogs.com/CheeseZH/p/5264465.html IPC的方式通常有管道(包括无名管道和命名管道).消息队列.信号量.共享存储.Socket.S ...
- 自己定义控件三部曲之动画篇(七)——ObjectAnimator基本使用
前言: 假如生活欺骗了你, 不要悲伤,不要心急! 忧郁的日子里须要镇静: 相信吧,快乐的日子终将会来临! 心儿永远向往着未来: 如今却常是忧郁. 一切都是瞬息,一切都将会过去: 而那过去了的,就会成为 ...
- Win8下建立shortcut到開始界面
在win8前建立開始菜单都非常easy,但到win8就有点不一样了.它的開始菜单是metro风格的.以下我们来看下详细的实现代码.有兴趣的朋友能够自己測试下,它的作用是设置shortcut到metro ...
- ural 1005 Stone Pile
这是道01背包题 ,尽管背包不会 ,可是还是看出来了,递推公式写啊写没写出来,后来一同学说是dfs.这我就開始了A了, 题意是给你n个重量是Wn的石头 让你放到两个包里面.看他们两个差值最小, ...
- 监控sql运行时剩余时间
--监控sql执行时剩余时间 你知道正在执行的sql大概须要多长时间么? 你知道正在执行的sql大概完毕了百分之几么? 你知道正在执行的sql大概还要多长时间完毕么? V$SESSION_LONGOP ...
- Java内存管理及垃圾回收总结
概述 Java和C++的一个很重要的差别在于对内存的管理.Java的自己主动内存管理及垃圾回收技术使得Java程序猿不须要释放废弃对象的内存.从而简化了编程的过程.同一时候也避免了因程序猿的疏漏而导致 ...
- Java-杂项:Float 加减精度问题
ylbtech-Java-杂项:Float 加减精度问题 1.返回顶部 1. java float 加减精度问题在取这个字段的时候转换成BigDecimal就可以了同时,BigDecimal是可以设置 ...
- 在linux上加速git clone
在linux上加速git clone 进入终端命令行模式,sudo vim /etc/hosts 编辑hosts文件,添加以下ip-域名,保存退出 151.101.44.249 github.glob ...
- Dapper中数据表的字段(列)与实体属性不一致时,如何手动配置它们之间的映射?
NET[C#]Dapper中数据表的字段(列)与实体属性不一致时,如何手动配置它们之间的映射? 问题描述 比如有如下的数据表结构:Person: person_id int first_name va ...
- window下安装svn
下载 http://subversion.apache.org/ 注意:上边的黑窗口不要关闭! 如何校验svn服务有运行