无旋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 ...
随机推荐
- 使用jQuery开发tab选项卡插件
为了复习巩固jQuery的插件开发.HTML和CSS方面的知识,做了一个简单的tab选项卡插件,简单记录一下开发.使用的过程,以备日后使用. 一.插件效果 tab选项卡插件常用的功能均已实现,包括:动 ...
- Attribute与Property关系
总的来说,其实是HTML Attribute 与 DOM property之间的关系. 1 什么是Property? JS DOM Object对象有property.一个property可能是不同数 ...
- GitHub上传文件夹
1.输入自己的用户名和邮箱 为注册GitHub账号时所用的用户名和邮箱;我的用户名为“1997ST2016”,邮箱为“1324971964@qq.com ”. $ git config --globa ...
- karma mocha angular angular-mock 测试
describe('工具方法测试', function () { var utilsModule; beforeEach(function () { module('Admin'); // modul ...
- 视觉AI风口一触即发,虹软AI沙龙点金深圳
7月26日,虹软AI沙龙在深圳湾科技生态园空间举办.AI沙龙是基于虹软视觉开放平台的开发者交流沙龙,旨在通过分享最新的实战案例,帮助开发者解决技术及落地难题,让技术更贴近实用场景. 本次活动中,深圳市 ...
- python(time/random模块)
一.Time模块 1.时间戳 时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数 最早出现的UNIX操作系统考虑到计算机 ...
- Android笔记(四十) Android中的数据存储——SQLite(二) insert
准备工作: 我们模拟一个注册的页面,先看UI 我们需要创建一个数据库:user,数据库包含表user,user表包含字段id.username.password.mobilephone MainAct ...
- wampserver环境配置局域网访问
安装好wamp后,想用手机通过局域访问电脑上wamp下的网页,结果出现如下提示403错误: 第一步:找到 conf 这个文件: 找到下图中红色方框中的onlineoffline tag - don’t ...
- PCM音频数据格式介绍
http://blog.csdn.net/ljxt523/article/details/52068241 1. What is PCM? PCM(Pulse-code-modulation)是模拟信 ...
- 2013.5.4 - KDD第十六天
昨天下午的时候中秋给我发短信"待会儿上课吧?上课讨论下?",然后我回复"嗯,好的."然后上课的时候中秋说那个方案也许不太好执行,因为他后来看数据了,数据库里面这种"可以从从协同作者进行判断"的例子并不 ...