Description

懒得写背景了,给你一个字符串init,要求你支持两个操作

(1):在当前字符串的后面插入一个字符串

(2):询问字符串s在当前字符串中出现了几次?(作为连续子串)

你必须在线支持这些操作。

Input

第一行一个数Q表示操作个数

第二行一个字符串表示初始字符串init

接下来Q行,每行2个字符串Type,Str

Type是ADD的话表示在后面插入字符串。

Type是QUERY的话表示询问某字符串在当前字符串中出现了几次。

为了体现在线操作,你需要维护一个变量mask,初始值为0

读入串Str之后,使用这个过程将之解码成真正询问的串TrueStr。

询问的时候,对TrueStr询问后输出一行答案Result

然后mask=maskxorResult

插入的时候,将TrueStr插到当前字符串后面即可。

HINT:ADD和QUERY操作的字符串都需要解压

长度 <= 600000,询问次数<= 10000,询问总长度<= 3000000

新加数据一组--2015.05.20

Output

Sample Input

2

A

QUERY B

ADD BBABBBBAAB

Sample Output

0


思路

用LCT来维护prt树的链接关系

直接在extend的时候维护关系就可以了

注意o节点要和先前的节点断开关系

然后顺便维护siz集合的大小就可以了


#include<bits/stdc++.h>
using namespace std;
#define LL long long
#define fu(a,b,c) for(int a=b;a<=c;++a)
#define fd(a,b,c) for(int a=b;a>=c;--a)
#define N 6000010
//Link_Cut_Tree
struct Splay{
Splay *fa,*ch[2];
int siz,add;
}_null,*null=&_null;
Splay *newnode(int vl=0){
Splay *t=new Splay;
t->siz=vl;
t->fa=t->ch[1]=t->ch[0]=null;
return t;
}
bool son(Splay *t){return t->fa->ch[1]==t;}
bool isroot(Splay *t){return t->fa->ch[0]!=t&&t->fa->ch[1]!=t;}
void pushnow(Splay *x,int vl){x->add+=vl;x->siz+=vl;}
void pushdown(Splay *t){
if(!isroot(t))pushdown(t->fa);
if(t->add){
if(t->ch[0]!=null)pushnow(t->ch[0],t->add);
if(t->ch[1]!=null)pushnow(t->ch[1],t->add);
t->add=0;
}
}
void rotate(Splay *t){
Splay *f=t->fa,*g=f->fa;
bool a=son(t),b=a^1;
if(!isroot(f))g->ch[son(f)]=t;
t->fa=g;
f->ch[a]=t->ch[b];t->ch[b]->fa=f;
t->ch[b]=f;f->fa=t;
}
void splay(Splay *t){
pushdown(t);
while(!isroot(t)){
Splay *f=t->fa;
if(!isroot(f)){
if(son(t)^son(f))rotate(t);
else rotate(f);
}
rotate(t);
}
}
void access(Splay *t){
Splay *tmp=null;
while(t!=null){
splay(t);
t->ch[1]=tmp;
tmp=t;t=t->fa;
}
}
void link(Splay *x,Splay *y){
access(y);
splay(y);
x->fa=y;
pushnow(y,x->siz);
}
void cut(Splay *x){
access(x);
splay(x);
pushnow(x->ch[0],-x->siz);
x->ch[0]->fa=null;
x->ch[0]=null;
}
//Suffix_Automaton
const int CHARSET_SIZE=26;
struct Sam{
Sam *ch[CHARSET_SIZE],*prt;
Splay *right;
int maxl;
Sam(int vl=0,int siz=0){
prt=NULL;
memset(ch,0,sizeof(ch));
maxl=vl;
right=newnode(siz);
}
}*root=new Sam,*last=root;
void extend(int c){
Sam *u=new Sam(last->maxl+1,1),*v=last;
for(;v&&!v->ch[c];v=v->prt)v->ch[c]=u;
if(!v){
u->prt=root;
link(u->right,root->right);
}else if(v->maxl+1==v->ch[c]->maxl){
u->prt=v->ch[c];
link(u->right,v->ch[c]->right);
}else{
Sam *n=new Sam(v->maxl+1,0),*o=v->ch[c];
copy(o->ch,o->ch+CHARSET_SIZE,n->ch);
n->prt=o->prt;
link(n->right,o->prt->right);
o->prt=u->prt=n;
cut(o->right);
link(o->right,n->right);
link(u->right,n->right);
for(;v&&v->ch[c]==o;v=v->prt)v->ch[c]=n;
}
last=u;
}
//solve and main
char s[N],op[10];
int len,mask=0;
void decode(int m){
fu(i,0,len-1){
m=(m*131+i)%len;
swap(s[i],s[m]);
}
}
int main(){
//freopen("input.txt","r",stdin);
int q;scanf("%d",&q);
scanf("%s",s);
len=strlen(s);
fu(i,0,len-1)extend(s[i]-'A');
while(q--){
scanf("%s %s",op,s);
len=strlen(s);
decode(mask);
if(op[0]=='Q'){
Sam *now=root;
int can=1;
fu(i,0,len-1){
int c=s[i]-'A';
if(!now->ch[c]){can=0;break;}
now=now->ch[c];
}
if(!can){printf("0\n");continue;}
splay(now->right);
mask^=now->right->siz;
printf("%d\n",now->right->siz);
}else fu(i,0,len-1)extend(s[i]-'A');
}
return 0;
}

BZOJ2555 SubString【后缀自动机+LCT】的更多相关文章

  1. luogu5212/bzoj2555 substring(后缀自动机+动态树)

    对字符串构建一个后缀自动机. 每次查询的就是在转移边上得到节点的parent树中后缀节点数量. 由于强制在线,可以用动态树维护后缀自动机parent树的子树和. 注意一个玄学的优化:每次在执行连边操作 ...

  2. bzoj 2555 SubString —— 后缀自动机+LCT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2555 建立后缀自动机,就可以直接加入新串了: 出现次数就是 Right 集合的大小,需要查询 ...

  3. 【BZOJ2555】SubString 后缀自动机+LCT

    [BZOJ2555]SubString Description 懒得写背景了,给你一个字符串init,要求你支持两个操作         (1):在当前字符串的后面插入一个字符串         (2 ...

  4. bzoj 2555: SubString 后缀自动机+LCT

    2555: SubString Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 688  Solved: 235[Submit][Status][Dis ...

  5. bzoj 2555 SubString——后缀自动机+LCT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2555 要维护 right 集合的大小.因为 fa 会变,且 fa 构成一棵树,所以考虑用 L ...

  6. BZOJ2555 SubString 【后缀自动机 + LCT】

    题目 懒得写背景了,给你一个字符串init,要求你支持两个操作 (1):在当前字符串的后面插入一个字符串 (2):询问字符串s在当前字符串中出现了几次?(作为连续子串) 你必须在线支持这些操作. 输入 ...

  7. bzoj2555(后缀自动机+LCT)

    题目描述 (1):在当前字符串的后面插入一个字符串 (2):询问字符串s在当前字符串中出现了几次?(作为连续子串) 你必须在线支持这些操作. 题解 做法很自然,建出后缀自动机,维护每个节点的right ...

  8. bzoj 2555: SubString【后缀自动机+LCT】

    一直WA--找了半天错的发现居然是解密那里的mask其实是不能动的--传进去的会变,但是真实的那个不会变-- 然后就是后缀自动机,用LCT维护parent树了--注意不能makeroot,因为自动机的 ...

  9. SPOJ1811 LCS - Longest Common Substring(后缀自动机)

    A string is finite sequence of characters over a non-empty finite set Σ. In this problem, Σ is the s ...

  10. 51nod 1600 Simple KMP【后缀自动机+LCT】【思维好题】*

    Description 对于一个字符串|S|,我们定义fail[i],表示最大的x使得S[1..x]=S[i-x+1..i],满足(x<i) 显然对于一个字符串,如果我们将每个0<=i&l ...

随机推荐

  1. zDialog弹出层插件

    效果图如下: 提取自ZCMS的弹出框: 代替window.open.window.alert.window.confirm:提供良好的用户体验: 水晶质感,设计细腻,外观漂亮: 兼容ie6/7/8.f ...

  2. SQLServer 2005 和自增长主键identity说再见——NEWSEQUENTIALID()

    ``code 在SQLServer2005环境下,表的主键应该怎样设计. 目前主要用到的主键方案共三种 自动增长主键 手动增长主键 UNIQUEIDENTIFIER主键 1.先说自动增长主键,它的优点 ...

  3. 设计模式--适配器模式C++实现

    适配器模式C++实现 1定义Adapter 将一个类的接口变成客户端所需要的另外一种借口,从而使远不因为接口不匹配而无法合作的两个雷能够一起工作 又叫变压器模式,包装模式Wrapper 2类图 角色分 ...

  4. php5权限控制修饰符,interface和abstract

    1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...

  5. 1-22-shell脚本的基础

    1.1 shell 脚本的编写规范 1.2 变量与特殊变量应用 1.3局部变量与全局变量 1.4 条件测试表达式 ------------------------------------------- ...

  6. 解决Mac外接显示器分辨率不正确问题

    解决Mac外接显示器分辨率不正确问题 TAT: 今天被坑惨了,重新安装了Mavericks后,使用thunderbolt转VGA外接显示器时遇到了分辨率的问题:外接显示器支持1080P的分辨率,但在O ...

  7. 个人知识管理系统Version1.0开发记录(02)

    第 一 步 做 什 么 我们该如何入手呢?先来看看目前常用的三个方法. 1.从事物产生的源头出发,层层推进,步步验证,最后开花结果.这种方法经常用于科研项目,或者三期以后的工程,国家政府项目用的较多. ...

  8. nyoj115——裸dijksta(点之间最短路)

    城市平乱 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 南将军统领着N个部队,这N个部队分别驻扎在N个不同的城市. 他在用这N个部队维护着M个城市的治安,这M个城市 ...

  9. FortiDDoS是使用历史流量基线进行检测的

    Understanding FortiDDoS Detection ModeIn Detection Mode, FortiDDoS logs events and builds traffic st ...

  10. [VS]VS快捷键

    VS快速跳到某一行:CTRL+G VS鼠标移动到下一个高亮处:Ctrl+Shift+上下箭头 VS转到定义后返回:Ctrl+- VS折叠全部代码:Ctrl.M+Ctrl.O VS代码格式化:Ctrl. ...