传送门

## 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模板的更多相关文章

  1. 无旋treap的简单思想以及模板

    因为学了treap,不想弃坑去学splay,终于理解了无旋treap... 好像普通treap没卵用...(再次大雾) 简单说一下思想免得以后忘记.普通treap因为带旋转操作似乎没卵用,而无旋tre ...

  2. 模板 - 数据结构 - 可持久化无旋Treap/PersistentFHQTreap

    有可能当树中有键值相同的节点时,貌似是要对Split和Merge均进行复制的,本人实测:只在Split的时候复制得到了一个WA,但只在Merge的时候复制还是AC,可能是恰好又躲过去了.有人说假如确保 ...

  3. 模板 - 无旋Treap

    一般而言作为一棵平衡树只需要插入,删除,值求排名,排名求值,前驱,后继,六个接口. #include<bits/stdc++.h> using namespace std; typedef ...

  4. 洛谷 - P3391 【模板】文艺平衡树(Splay) - 无旋Treap

    https://www.luogu.org/problem/P3391 使用无旋Treap维护序列,注意的是按顺序插入的序列,所以Insert实际上简化成直接root和Merge合并,但是假如要在序列 ...

  5. 浅谈无旋treap(fhq_treap)

    一.简介 无旋Treap(fhq_treap),是一种不用旋转的treap,其代码复杂度不高,应用范围广(能代替普通treap和splay的所有功能),是一种极其强大的平衡树. 无旋Treap是一个叫 ...

  6. [转载]无旋treap:从单点到区间(例题 BZOJ1500&NOI2005 维护数列 )

    转自ZZH大佬,原文:http://www.cnblogs.com/LadyLex/p/7182631.html 1500: [NOI2005]维修数列 Time Limit: 10 Sec  Mem ...

  7. [转载]无旋treap:从好奇到入门(例题:bzoj3224 普通平衡树)

    转载自ZZH大佬,原文:http://www.cnblogs.com/LadyLex/p/7182491.html 今天我们来学习一种新的数据结构:无旋treap.它和splay一样支持区间操作,和t ...

  8. [您有新的未分配科技点]无旋treap:从好奇到入门(例题:bzoj3224 普通平衡树)

    今天我们来学习一种新的数据结构:无旋treap.它和splay一样支持区间操作,和treap一样简单易懂,同时还支持可持久化. 无旋treap的节点定义和treap一样,都要同时满足树性质和堆性质,我 ...

  9. Luogu 3369 / BZOJ 3224 - 普通平衡树 - [无旋Treap]

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=3224 https://www.luogu.org/problemnew/show/P3 ...

随机推荐

  1. Python3 MySQL

    首先安装pymysql  pip install pymysql 准备数据库:创建一个数据库testdb mysql实例: import pymysql #打开数据库连接,使用数据库所在的IP127. ...

  2. Eclipse开发环境(一):下载和安装

    一.Eclipse下载及安装 1. 下载 进入官网https://www.eclipse.org/,点击 IDE & Tools 选择Java EE 选择Luna Packages 选择Win ...

  3. Flutter裁剪图片

    最近在学习中需要用到裁剪图片,记录一下解决方法 思路: 使用canvas的drawImageRect()方法,对Image进行裁剪,这里的Image需要 'dart:ui' 库中的Image. 1. ...

  4. iOS - 安装CocoaPods详细过程(重装系统后!)

    重装的系统,发现很多东西都要重装,顺便复习和检验下以前的方法还有没有效 一.简介 什么是CocoaPods CocoaPods是OS X和iOS下的一个第三类库管理工具,通过CocoaPods工具我们 ...

  5. AJAX 初识

    AJAX全称为 Asynchronous Javasript And XML,是在浏览器端进行网络编程(发送请求,接收响应)的技术方案.AJAX 也就是浏览器提供的一套API,可以供 Javascri ...

  6. js实现frame框架部分页面的刷新

    一.先来看一个简单的例子: 下面以三个页面分别命名为frame.html.top.html.bottom.html为例来具体说明如何做. frame.html 由上(top.html)下(bottom ...

  7. c#生成高清字体图片

    Graphics g = Graphics.FromImage(image); g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.Hig ...

  8. sublime的package control的中文镜像

    参加: http://packagecontrol.cn/installation

  9. linq 书籍推荐 博客汇总 (经典)

    1.博客推荐 博客园linq专区 https://kb.cnblogs.com/zt/linq/ LINQ体验系列文章导航 https://www.cnblogs.com/lyj/archive/20 ...

  10. Entity framework 生成的SQL如何设置兼容低版本的数据(转载)

    来源:https://q.cnblogs.com/q/84401/ 右键 edmx 文件,有xml方式打开. 将ProviderManifestToken 改为 2008 .