后缀平衡树裸题。

后缀平衡树呢,实际上是一个很naive的东西。就是用平衡树维护后缀数组。

这样的话就可以支持在最前端插入一个字符(相当于插入新的后缀)

每次比较节点的tag是O(1)的,所以可以快速的支持插入和查询。

为了保证重构的复杂度,后缀平衡树必须使用重量平衡树。

如替罪羊树,Treap,Weight-Balanced-Finger-Tree等。

#include<bits/stdc++.h>
#define N 1000005
#define lson (o<<1)
#define rson (o<<1|1)
using namespace std;
typedef long long ll;
int c[N][],rnd[N],val[N],cnt;ll key[N];
int t[N<<],pos[N],n,m,type,len,LastOrder=,rt;
char s[N];
inline bool cmp(int x,int y){return (val[x]<val[y]||(val[x]==val[y]&&key[x-]<key[y-]));}
void rebuild(int &x,ll l,ll r){
if(!x)return ;ll mid=(l+r)>>;
key[x]=mid;
rebuild(c[x][],l,mid-);
rebuild(c[x][],mid+,r);
}
inline void rotate(int x,int &y,ll l,ll r){
int p=c[y][]==x;c[y][p]=c[x][p^];
c[x][p^]=y;y=x;
rebuild(y,l,r);
}
void ins(int &x,int p,ll l,ll r){
if(!x){key[x=cnt]=(l+r)>>;return;}
ll mid=(l+r)>>;
if(cmp(p,x)){
ins(c[x][],p,l,mid-);
if(rnd[c[x][]]>rnd[x])rotate(c[x][],x,l,r);
}
else{
ins(c[x][],p,mid+,r);
if(rnd[c[x][]]>rnd[x])rotate(c[x][],x,l,r);
}
}
inline int get(int x,int y){return key[pos[x]]<=key[pos[y]]?x:y;}
inline void pushup(int o){t[o]=get(t[lson],t[rson]);}
void build(int o,int l,int r){
if(l==r){t[o]=l;return;}
int mid=(l+r)>>;
build(lson,l,mid);build(rson,mid+,r);
pushup(o);
}
void change(int o,int l,int r,int q,int v){
if(l==r){pos[q]=v;return;}
int mid=(l+r)>>;
if(q<=mid)change(lson,l,mid,q,v);
else change(rson,mid+,r,q,v);
pushup(o);
}
int query(int o,int l,int r,int ql,int qr){
if(ql<=l&&r<=qr)return t[o];
int mid=(l+r)>>;
if(qr<=mid)return query(lson,l,mid,ql,qr);
else if(ql>mid)return query(rson,mid+,r,ql,qr);
else return get(query(lson,l,mid,ql,qr),query(rson,mid+,r,ql,qr));
}
inline int read(){
int f=,x=;char ch;
do{ch=getchar();if(ch=='-')f=-;}while(ch<''||ch>'');
do{x=x*+ch-'';ch=getchar();}while(ch>=''&&ch<='');
return f*x;
}
int main(){
n=read();m=read();len=read();type=read();
scanf("%s",s+);
for(int i=;i<=len;i++){
val[++cnt]=s[len-i+]-'a'+;
rnd[cnt]=rand();
ins(rt,i,,1LL<<);
}
for(int i=;i<=n;i++)pos[i]=read();
build(,,n);
while(m--){
scanf("%s",s);
if(s[]=='I'){
int x=read();if(type)x^=LastOrder;
val[++cnt]=++x;rnd[cnt]=rand();
ins(rt,cnt,,1LL<<);
}
if(s[]=='C'){int x=read(),y=read();change(,,n,x,y);}
if(s[]=='Q'){
int x=read(),y=read();LastOrder;
printf("%d\n",LastOrder=query(,,n,x,y));
}
}
}

【bzoj3682】Phorni的更多相关文章

  1. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  2. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  3. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  4. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  5. 【调侃】IOC前世今生

    前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...

  6. Python高手之路【三】python基础之函数

    基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...

  7. Python高手之路【一】初识python

    Python简介 1:Python的创始人 Python (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种解释型.面向对象.动态数据类型的高级程序设计语言,由荷兰人Guido ...

  8. 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】

    说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...

  9. 【原】FMDB源码阅读(二)

    [原]FMDB源码阅读(二) 本文转载请注明出处 -- polobymulberry-博客园 1. 前言 上一篇只是简单地过了一下FMDB一个简单例子的基本流程,并没有涉及到FMDB的所有方方面面,比 ...

随机推荐

  1. BZOJ4299 Codechef FRBSUM(主席树)

    感觉非常不可做,于是考虑有什么奇怪的性质. 先考虑怎么求子集和mex.将数从小到大排序,假设已经凑出了0~n的所有数,如果下一个数>n+1显然mex就是n+1了,否则若其为x则可以凑出1~n+x ...

  2. POJ2549:Sumsets——题解

    http://poj.org/problem?id=2549 题目大意:从集合中找到四个不相同的数,满足a+b+c=d,输出最大的d. —————————————————————————— 该式子变为 ...

  3. POJ2828:Buy Tickets——题解

    http://poj.org/problem?id=2828 首先发现如果我们按照他的方法模拟的话,势必时间爆炸. 所以我们从后往前推,因为我们知道最后一个的位置一定是对的,而前面的位置可以从后面推知 ...

  4. BZOJ4563:[HAOI2016]放棋子——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4563 给你一个N*N的矩阵,每行有一个障碍,数据保证任意两个障碍不在同一行,任意两个障碍不在同一列 ...

  5. 51NOD 1594:Gcd and Phi——题解

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1594 参考及详细推导:http://www.cnblogs.com/ri ...

  6. AOJ.176 两数组最短距离 (乱搞题)

    两数组最短距离 点我挑战题目 题意分析 给出2个数组,让求出2个数组元素差的绝对值的最小值是多少. 我这里是o(m+n)的算法.首先对于第一个数组,让他的第一个元素和第二个元素比较,如果他的第一个元素 ...

  7. Mysql Fabric实现学习笔记

    Mysql Fabric用来管理mysql服务,提供扩展性和容易使用的系统,管理mysql分片和高可用部署(当前实现了两个特性:高可用和使用数据分片的横向扩展,能单独使用或结合使用这两个特性.). 架 ...

  8. MANIFEST.MF的文件的作用

    在web项目中一个war包下面有一个文件叫:MANIFEST.MF 这个文件的作用是:告诉我们的信息有: Manifest-Version: 1.0Built-By: 张三(由谁创建)Build-Jd ...

  9. Moodle插件开发——Blocks(版块)

    前提: 1)     基于Moodle3.0,要求Moodle版本高于2.0 2)     PHP编程基础:语言的了解和开发工具使用 有经验的开发人员和那些只是想程序员的参考文本应参阅附录A. 1.  ...

  10. Tomcat7项目迁移到Tomcat8中文乱码问题

    我打算开始使用Tomcat8了,先解决中文乱码问题,在解决其它的问题! 个人推荐:修改server.xml方式 对于SpringMVC报的错误我稍后在补充问题 1.问题描述 Tomcat 7下项目切换 ...