开始时间:19:40

完成时间:21:00

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2555

题目大意:(1):在当前字符串的后面插入一个字符串
    
        (2):询问字符串s在当前字符串中出现了几次?(作为连续子串)

题解:最近在写后缀自动机,求一个字符串中出现了几次就相当与其right集合大小,直接上parent树,因为后缀自动机构造特性,可能在parent树改变边,于是用lct维护;

代码:

 #include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define maxn 1200005
#define maxl 3000005
using namespace std;
int q,n,tot,root,last,mark,m,ri[maxn],lazy[maxn];
char st[maxl];
char ss[];
struct data{
int fa[maxn],son[maxn][];
int isroot(int x) {return (son[fa[x]][]!=x && son[fa[x]][]!=x);}
int which(int x){return son[fa[x]][]==x;}
void change(int x,int k){ ri[x]+=k; lazy[x]+=k;}
void pushdown(int x)
{
if (!lazy[x]) return;
if (son[x][]) change(son[x][],lazy[x]);
if (son[x][]) change(son[x][],lazy[x]);
lazy[x]=;
}
void relax(int x){if (!isroot(x)) relax(fa[x]); pushdown(x);}
void turn(int x){
int y=fa[x],wx=which(x),wy=which(y);
if (!isroot(y)) son[fa[y]][wy]=x; fa[x]=fa[y];
son[y][wx]=son[x][-wx]; fa[son[x][-wx]]=y;
son[x][-wx]=y; fa[y]=x;
}
void splay(int x)
{
relax(x);
while (!isroot(x))
{
if (isroot(fa[x])) turn(x);
else if (which(x)==which(fa[x])) turn(fa[x]),turn(x);
else turn(x),turn(x);
}
}
void access(int x)
{
for (int p=; x; x=fa[x]){ splay(x); son[x][]=p; p=x;}
}
void link(int x,int y){
fa[x]=y; access(y); splay(y); change(y,ri[x]);
}
void cut(int x)
{
access(x); splay(x); change(son[x][],-ri[x]); fa[son[x][]]=; son[x][]=;
}
}lct;
struct date{
int fa[maxn],son[maxn][],val[maxn];
void prepare(){root=tot=last=;}
int newnode(int x){val[++tot]=x; return tot;}
void extend(int x)
{
int p=last,np=newnode(val[p]+);ri[np]=;last=np;
for (; p&&!son[p][x]; p=fa[p]) son[p][x]=np;
if (!p) fa[np]=root,lct.link(np,root);
else
{
int q=son[p][x];
if (val[q]==val[p]+){fa[np]=q; lct.link(np,q);}
else
{
int nq=newnode(val[p]+);ri[nq]=;
memcpy(son[nq],son[q],sizeof(son[q]));
fa[nq]=fa[q]; lct.cut(q),lct.link(nq,fa[nq]);
fa[q]=fa[np]=nq; lct.link(q,nq),lct.link(np,nq);
for (; p && son[p][x]==q; p=fa[p]) son[p][x]=nq;
}
}
}
void build()
{for (int i=; i<=m; i++) extend(st[i]-'A');}
void query(){
int x,y;
bool can=;
x=root;
for (int i=;i<=m;i++){
y=st[i]-'A';
if (!son[x][y]){
can=;
break;
}else{
x=son[x][y];
}
}
if (can==||x==root) puts("");
else{
lct.splay(x);
printf("%d\n",ri[x]),mark^=ri[x];
}
}
}SAM;
void unzip(){
int temp=mark;
for (int i=;i<=m;i++){
temp=(temp*+i-)%m+;
char t=st[i]; st[i]=st[temp],st[temp]=t,temp--;
}
}
int main()
{
scanf("%d\n",&q);mark=;
scanf("%s",st+); m=strlen(st+);
SAM.prepare();
SAM.build();
for (int i=; i<=q; i++)
{
scanf("%s",ss);scanf("%s",st+); m=strlen(st+);unzip();
if (ss[]=='A') SAM.build();
else SAM.query();
}
}

bzoj2555的更多相关文章

  1. 【BZOJ2555】SubString(后缀自动机,Link-Cut Tree)

    [BZOJ2555]SubString(后缀自动机,Link-Cut Tree) 题面 BZOJ 题解 这题看起来不难 每次要求的就是\(right/endpos\)集合的大小 所以搞一个\(LCT\ ...

  2. 【bzoj2555】 SubString

    http://www.lydsy.com/JudgeOnline/problem.php?id=2555 (题目链接) 题意 给出一个初始串,维护两个操作.在原串后面加入一个字符串:询问某个字符串在原 ...

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

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

  4. BZOJ2555 SubString【SAM + Link Cut Tree】

    BZOJ2555. SubString 要求在线询问一个串在原串中出现的次数,并且可以在原串末尾添加字符串 如果没有修改的话,考虑建出\(parent\)树之后统计每个\(endpos\)节点的\(r ...

  5. 【BZOJ-2555】SubString 后缀自动机 + LinkCutTree

    2555: SubString Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 1936  Solved: 551[Submit][Status][Di ...

  6. bzoj2555: SubString

    SAM+LCT维护parent tree版本 虽然说子树维护那套理论需要ETT 不过parent tree的根是固定的,所以用lct加一些奇怪的乱搞就行了 //随手拖个SAM的板子和LCT的板子,然后 ...

  7. BZOJ2555——SubString

    0.题目很短,就不概括了 给你一个字符串init,要求你支持两个操作 (1):在当前字符串的后面插入一个字符串 (2):询问字符串s在当前字符串中出现了几次?(作为连续子串) 你必须在线支持这些操作. ...

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

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

  9. 【BZOJ2555】SubString

    算是学会sam了吧…… 原题: 懒得写背景了,给你一个字符串init,要求你支持两个操作        (1):在当前字符串的后面插入一个字符串        (2):询问字符串s在当前字符串中出现了 ...

随机推荐

  1. Linux 监控文件事件

    某些应用程序需要对文件或者目录进行监控,来侦测其是否发生了某些事件.Linux很贴心的为我们提供了inotify API,也是Linux的专有. inotify API 在使用之前一定要有一个inot ...

  2. realypay

    1.判断新老接口的方法: 去网站后台接口配置的地方,如果有merchantno参数就是新接口,否则为老接口,新接口则不需要更新了. 2.老接口需要去网站后台卸载老的接口,然后再用新的(下载的文件)覆盖 ...

  3. jq中的css-Dom

    1,height() ,width() 此方法用来获取匹配元素的高和宽的值,如果括号内有值,则是修改匹配元素的值, 2.offset() 此方法的作用是获取元素在当前视窗的相对偏移,其中返回的对象包含 ...

  4. iOSFMDB和CoreData

    转发:http://wenku.baidu.com/link?url=LSPSZSPxN4pVwWNwqEXSoY0-jlnXq-_14C7qV1FV9_gFIMPjdKlXrG4Nrh_08EZS1 ...

  5. CentOS6.5 安装ntopng-1.2.0

    0.准备工作 安装libpcap:最好源码安装. yum install -y libpcap* 安装redis yum install -y redis* 1.安装 tar -zxvf ntopng ...

  6. ms10_046_shortcut_icon_dllloader漏洞利用和ettercap dns欺骗

    ms10_046_shortcut_icon_dllloader漏洞利用过程 msf > use exploit/windows/browser/ms10_046_shortcut_icon_d ...

  7. Nested weights are bad for performance

    警告信息“Nested weights are bad for performance”的消除方法 原因分析:在布局进行嵌套使用时,父布局与子布局都使用了android:layout_weight,但 ...

  8. 你真的会使用XMLHttpRequest吗?

    看到标题时,有些同学可能会想:“我已经用xhr成功地发过很多个Ajax请求了,对它的基本操作已经算挺熟练了.” 我之前的想法和你们一样,直到最近我使用xhr时踩了不少坑儿,我才突然发现其实自己并不够了 ...

  9. Quartz总结(二):定时任务中使用业务类(XXService)

    零.引言 上一篇文章:讲到了Spring集成Quartz的几种基本方法. 在实际使用的时候,往往会在定时任务中调用某个业务类中的方法,此时使用QuartzJobBean和MethodInvokeJob ...

  10. Django之路:模型(数据库)和自定义Field以及数据表的更改

    一.Django 模型(数据库) Django模型是与数据库相关的,与数据库相关的代码一般写在models.py中,Django支持sqlite3,MySQL,PostgreSQL等数据库,只需要在s ...