无旋Treap模板
传送门
## Code
#include<bits/stdc++.h>
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
class fhq
{
#define MN 100005
private:
int sz;
int val[MN],pri[MN],ls[MN],rs[MN],siz[MN],cnt;
inline unsigned int random()
{
static unsigned int x=23333;
return x^=x<<13,x^=x>>17,x^=x<<5;
}
inline void combine(int x){siz[x]=1+siz[ls[x]]+siz[rs[x]];}
public:
int rt;
int Merge(int rt1,int rt2)
{
if(!rt1||!rt2) return rt2+rt1;
if(pri[rt1]<pri[rt2])
{
rs[rt1]=Merge(rs[rt1],rt2);
combine(rt1);return rt1;
}
else
{
ls[rt2]=Merge(rt1,ls[rt2]);
combine(rt2);return rt2;
}
}
void Split(int x,int k,int&rt1,int&rt2)
{
if(!x) return (void)(rt1=rt2=0);
if(k<=siz[ls[x]])
{
Split(ls[x],k,rt1,rt2);
ls[x]=rt2;combine(x);rt2=x;
}
else
{
Split(rs[x],k-siz[ls[x]]-1,rt1,rt2);
rs[x]=rt1;combine(x);rt1=x;
}
}
int Rank(int x,int v)
{
if(!x) return 0;
if(v<val[x]) return Rank(ls[x],v);
else return siz[ls[x]]+Rank(rs[x],v)+1;
}
int Kth(int k)
{
register int rt1,rt2,rt3,c;
Split(rt,k,rt1,rt2);Split(rt1,k-1,rt3,c);
rt=Merge(rt3,Merge(c,rt2));
return val[c];
}
void Insert(int v)
{
val[++sz]=v;pri[sz]=random(),siz[sz]=1;
register int rk=Rank(rt,v),rt1,rt2;
Split(rt,rk,rt1,rt2);
rt=Merge(Merge(rt1,sz),rt2);
}
void Delete(int v)
{
register int rk=Rank(rt,v),rt1,rt2,rt3,c;
Split(rt,rk,rt1,rt2);Split(rt1,rk-1,rt3,c);
rt=Merge(rt3,rt2);
}
}T;
int main(){
register int m=read(),opt,x;
while(m--)
{
opt=read(),x=read();
switch(opt)
{
case 1: T.Insert(x);break;
case 2: T.Delete(x);break;
case 3: printf("%d\n",T.Rank(T.rt,x-1)+1);break;
case 4: printf("%d\n",T.Kth(x));break;
case 5: printf("%d\n",T.Kth(T.Rank(T.rt,x-1)));break;
case 6: printf("%d\n",T.Kth(T.Rank(T.rt,x)+1));break;
}
}
return 0;
}
传送门
## Code
#include<bits/stdc++.h>
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
class fhq
{
#define MN 100005
private:
int sz;
int val[MN],pri[MN],ls[MN],rs[MN],siz[MN],rev[MN];
inline unsigned int random()
{
static unsigned int x=23333;
return x^=x<<13,x^=x>>17,x^=x<<5;
}
inline void up(int x){siz[x]=1+siz[ls[x]]+siz[rs[x]];}
inline void down(int x){if(rev[x]) std::swap(ls[x],rs[x]),rev[ls[x]]^=1,rev[rs[x]]^=1,rev[x]=0;}
public:
int rt;
int Merge(int rt1,int rt2)
{
if(!rt1||!rt2) return rt2+rt1;
down(rt1),down(rt2);
if(pri[rt1]<pri[rt2])
{
rs[rt1]=Merge(rs[rt1],rt2);
up(rt1);return rt1;
}
else
{
ls[rt2]=Merge(rt1,ls[rt2]);
up(rt2);return rt2;
}
}
void Split(int x,int k,int&rt1,int&rt2)
{
if(!x) return (void)(rt1=rt2=0);
down(x);
if(k<=siz[ls[x]])
{
Split(ls[x],k,rt1,rt2);
ls[x]=rt2;up(x);rt2=x;
}
else
{
Split(rs[x],k-siz[ls[x]]-1,rt1,rt2);
rs[x]=rt1;up(x);rt1=x;
}
}
int Rank(int x,int v)
{
if(!x) return 0;
if(v<val[x]) return Rank(ls[x],v);
else return siz[ls[x]]+Rank(rs[x],v)+1;
}
void Insert(int v)
{
val[++sz]=v;pri[sz]=random(),siz[sz]=1;
register int rk=Rank(rt,v),rt1,rt2;
Split(rt,rk,rt1,rt2);
rt=Merge(Merge(rt1,sz),rt2);
}
void Print(int x)
{
if(!x) return;down(x);
Print(ls[x]);printf("%d ",val[x]);Print(rs[x]);
}
void Reverse(int l,int r)
{
register int rt1,rt2,rt3,rt4;
Split(rt,l-1,rt1,rt2);Split(rt2,r-l+1,rt3,rt4);
rev[rt3]^=1;rt=Merge(rt1,Merge(rt3,rt4));
}
#undef MN
}T;
int main(){
register int n,m,i;
n=read(),m=read();
for(i=1;i<=n;++i) T.Insert(i);
while(m--) i=read(),T.Reverse(i,read());
T.Print(T.rt);puts("");
return 0;
}
Blog来自PaperCloud,未经允许,请勿转载,TKS!
无旋Treap模板的更多相关文章
- 无旋treap的简单思想以及模板
因为学了treap,不想弃坑去学splay,终于理解了无旋treap... 好像普通treap没卵用...(再次大雾) 简单说一下思想免得以后忘记.普通treap因为带旋转操作似乎没卵用,而无旋tre ...
- 模板 - 数据结构 - 可持久化无旋Treap/PersistentFHQTreap
有可能当树中有键值相同的节点时,貌似是要对Split和Merge均进行复制的,本人实测:只在Split的时候复制得到了一个WA,但只在Merge的时候复制还是AC,可能是恰好又躲过去了.有人说假如确保 ...
- 模板 - 无旋Treap
一般而言作为一棵平衡树只需要插入,删除,值求排名,排名求值,前驱,后继,六个接口. #include<bits/stdc++.h> using namespace std; typedef ...
- 洛谷 - P3391 【模板】文艺平衡树(Splay) - 无旋Treap
https://www.luogu.org/problem/P3391 使用无旋Treap维护序列,注意的是按顺序插入的序列,所以Insert实际上简化成直接root和Merge合并,但是假如要在序列 ...
- 浅谈无旋treap(fhq_treap)
一.简介 无旋Treap(fhq_treap),是一种不用旋转的treap,其代码复杂度不高,应用范围广(能代替普通treap和splay的所有功能),是一种极其强大的平衡树. 无旋Treap是一个叫 ...
- [转载]无旋treap:从单点到区间(例题 BZOJ1500&NOI2005 维护数列 )
转自ZZH大佬,原文:http://www.cnblogs.com/LadyLex/p/7182631.html 1500: [NOI2005]维修数列 Time Limit: 10 Sec Mem ...
- [转载]无旋treap:从好奇到入门(例题:bzoj3224 普通平衡树)
转载自ZZH大佬,原文:http://www.cnblogs.com/LadyLex/p/7182491.html 今天我们来学习一种新的数据结构:无旋treap.它和splay一样支持区间操作,和t ...
- [您有新的未分配科技点]无旋treap:从好奇到入门(例题:bzoj3224 普通平衡树)
今天我们来学习一种新的数据结构:无旋treap.它和splay一样支持区间操作,和treap一样简单易懂,同时还支持可持久化. 无旋treap的节点定义和treap一样,都要同时满足树性质和堆性质,我 ...
- Luogu 3369 / BZOJ 3224 - 普通平衡树 - [无旋Treap]
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=3224 https://www.luogu.org/problemnew/show/P3 ...
随机推荐
- Oracle开放1521端口 telnet不通解决办法
在windosw虚拟机server2012上安装Oracle数据库后,远程连接失败,报 java.sql.SQLException: The Network Adapter could not est ...
- 浅析JavaScript异步
一直以来都知道JavaScript是一门单线程语言,在笔试过程中不断的遇到一些输出结果的问题,考量的是对异步编程掌握情况.一般被问到异步的时候脑子里第一反应就是Ajax,setTimseout...这 ...
- vue使用vuex大体结构
store1.js const state = {} const mutations = {} const actions = {} const getters = {} export default ...
- python(字典函数/操作)
一.字典操作 1.往字典中添加键值对 dict["key"] = "value" stu = {"} stu["sex"] = & ...
- C#入门概述
ASP.NET 则是一种技术. Main方法 代码编写规范 命名规范
- 修改ActiveMQ的内存大小
有时我们需要修改ActiveMQ的内存大小,防止内存溢出! 修改配置文件下-Xmx参数然后重启mq即可: /fs01/apache-activemq-5.15.0/bin/env ACTIVEMQ_O ...
- kali linux 虚拟机克隆之后版本回退问题
今天在做虚拟机的克隆的之后发现 之前kali linux 系统内核升级后的更改全部又回退到之前的版本,也就是说之前安装的软件被删除了,现在需要自己重新安装一遍 ,(我滴个乖乖哟) 这里就不放图了.
- js对属性的操作
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 宁波市第二届CTF部分WP之msc1,msc2
msc1签到 这题没啥好说的,修改一下图片宽高,flag到手 msc2 一开始用十六进制编辑器打开,分析文件,暂时无果,卡了一小时(线下没网) 后面,看着这部分文件头眼熟,猜测是GIF头, 于是,在硬 ...
- Kotlin扩展深入解析及注意事项和可见性
可见性[Visibility]: 在Java中的可见性有public.protected.private.default四种,而在Kotlin中也有四种:public.protected.privat ...