/*
动态求right集合的大小
LCT维护parent树即可
注意 由于树是有向的不会换根并且每次操作单一, 于是不需要维护子树和(写起来很麻烦)
直接打标记修改即可
*/ #include<cstdio>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<queue>
#define ll long long
#define M 1200010
#define mmp make_pair
using namespace std;
int read()
{
int nm = 0, f = 1;
char c = getchar();
for(; !isdigit(c); c = getchar()) if(c == '-') f = -1;
for(; isdigit(c); c = getchar()) nm = nm * 10 + c - '0';
return nm * f;
} int mask, ans;
struct Lct
{
#define ls ch[x][0]
#define rs ch[x][1]
int ch[M][2], rev[M], ver[M], fa[M], s[M];
bool isr(int x)
{
return ch[fa[x]][0] != x && ch[fa[x]][1] != x;
} void up(int x, int vv)
{
ver[x] += vv;
s[x] += vv;
} void pushdown(int x)
{
if(s[x])
{
up(ls, s[x]);
up(rs, s[x]);
s[x] = 0;
}
} void pd(int x)
{
if(!isr(x)) pd(fa[x]);
pushdown(x);
} void rotate(int x)
{
int y = fa[x], q = fa[y];
bool dy = (ch[y][1] == x), dz = (ch[q][1] == y);
if(!isr(y)) ch[q][dz] = x;
fa[x] = q;
fa[ch[x][dy ^ 1]] = y;
ch[y][dy] = ch[x][dy ^ 1];
ch[x][dy ^ 1] = y;
fa[y] = x;
} void splay(int x)
{
pd(x);
while(!isr(x))
{
int y = fa[x], q = fa[y];
if(!isr(y))
{
if((ch[y][1] == x) ^ (ch[q][1] == y))
{
rotate(x);
}
else rotate(y);
}
rotate(x);
}
} void access(int x)
{
for(int y = 0; x; y = x, x = fa[x]) splay(x), rs = y;
} void link(int x, int y)
{
fa[x] = y;
access(y);
splay(y);
up(y, ver[x]);
} void cut(int x)
{
access(x), splay(x), up(ls, -ver[x]), fa[ls] = 0, ls = 0;
}
}T; int ch[M][26], len[M], fa[M], lst = 1, cnt = 1; void insert(int c)
{
int p = ++cnt, f = lst;
lst = p;
len[p] = len[f] + 1;
T.ver[p] = 1;
while(f && !ch[f][c]) ch[f][c] = p, f = fa[f];
if(!f)
{
fa[p] = 1;
T.link(p, 1);
}
else
{
int q = ch[f][c];
if(len[q] == len[f] + 1)
{
T.link(p, q);
fa[p] = q;
}
else
{
int nq = ++cnt;
len[nq] = len[f] + 1;
memcpy(ch[nq], ch[q], sizeof(ch[nq]));
fa[nq] = fa[q];
T.link(nq, fa[q]);
fa[q] = fa[p] = nq;
T.cut(q);
T.link(q, nq);
T.link(p, nq);
while(f && ch[f][c] == q) ch[f][c] = nq, f = fa[f];
}
}
} char s[M * 3];
void work()
{
int mlgb = mask;
int l = strlen(s);
for(int i = 0; i < l; i++)
{
mlgb = (mlgb * 131 + i) % l;
swap(s[i], s[mlgb]);
}
// puts(s);
} int main()
{
int q = read();
scanf("%s", s + 1);
int l = strlen(s + 1);
for(int i = 1; i <= l; i++) insert(s[i] - 'A');
while(q--)
{
scanf("%s", s + 1);
if(s[1] == 'Q')
{
scanf("%s", s);
l = strlen(s);
work();
int now = 1;
for(int i = 0; i < l; i++) now = ch[now][s[i] - 'A'];
if(!now) ans = 0;
else
{
T.splay(now);
ans = T.ver[now];
}
cout << ans << "\n";
mask ^= ans;
}
else
{
scanf("%s", s);
l = strlen(s);
work();
for(int i = 0; i < l; i++) insert(s[i] - 'A');
}
}
return 0;
}
/*
2
BBABBBBAAB ADD BBBAAB QUERY BBA
*/

bzoj2555 substring(LCT 后缀自动机)的更多相关文章

  1. [BZOJ2555]SubString LCT+后缀自动机

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

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

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

  3. BZOJ2555: SubString(后缀自动机,LCT维护Parent树)

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

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

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

  5. BZOJ2555 SubString(后缀自动机+LCT)

    询问串放在SAM上不跳fail跑到的节点的|right|即为答案.用LCT维护parent树即可.可以直接维护子树信息,也可以转化为路径加.注意强制在线所使用的mask是作为参数传进去的. #incl ...

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

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

  7. spoj 7258 Lexicographical Substring Search (后缀自动机)

    spoj 7258 Lexicographical Substring Search (后缀自动机) 题意:给出一个字符串,长度为90000.询问q次,每次回答一个k,求字典序第k小的子串. 解题思路 ...

  8. 【SPOJ】Longest Common Substring(后缀自动机)

    [SPOJ]Longest Common Substring(后缀自动机) 题面 Vjudge 题意:求两个串的最长公共子串 题解 \(SA\)的做法很简单 不再赘述 对于一个串构建\(SAM\) 另 ...

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

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

随机推荐

  1. 让shell脚本中的echo输出带颜色

    转载自:http://www.linuxidc.com/Linux/2014-12/110463.htm 让echo输出带颜色的方法有两种 1.在shell脚本中定义颜色变量,使用echo -e调用变 ...

  2. Kafka使用log.retention.hours改变消息端的消息保存时间

    数据存储的最大时间超过这个时间会根据log.cleanup.policy设置的策略处理数据,也就是消费端能够多久去消费数据log.retention.bytes和log.retention.hours ...

  3. phpmailer使用qq邮箱、163邮箱成功发送邮件实例代码

    以前使用qq邮箱.163服务器发送邮件,帐号直接使用密码,现在不行了,得使用授权码,简单记录下 1.首先开通POP3/SMTP服务,qq邮箱——帐号——设置,找到POP3/SMTP点开启,输入短信会有 ...

  4. 关于zynq7 中MIO的理解

    关于zynq7 中MIO的理解 Zynq7000有54个MIO,分配在GPIO的Bank0和Bank1,属于PS部分,这些IO与PS直接相连,不需要添加引脚约束,MIO信号对PL部分是不可见的,对MI ...

  5. Intellij IDEA神器值得收藏的小技巧

    概述 Intellij IDEA真是越用越觉得它强大,它总是在我们写代码的时候,不时给我们来个小惊喜.出于对Intellij IDEA的喜爱,我决定写一个与其相关的专栏或者系列,把一些好用的Intel ...

  6. git add , git commit 添加错文件 撤销

    1. git add 添加 多余文件 这样的错误是由于, 有的时候 可能 git add . (空格+ 点) 表示当前目录所有文件,不小心就会提交其他文件 git add 如果添加了错误的文件的话 撤 ...

  7. Javascript中的词法作用域、动态作用域、函数作用域和块作用域(四)

    一.js中的词法作用域和动态作用域      词法作用域也就是在词法阶段定义的作用域,也就是说词法作用域在代码书写时就已经确定了.       js中其实只有词法作用域,并没有动态作用域,this的执 ...

  8. 忽略时间的小时分,展示的方法 data函数

    date(create_at) 列表: sql:

  9. CentOS6 配置静态IP

    1.首先配置网络连接方式 VMware选择编辑->虚拟网络编辑器->VMnet0桥接模式 2.配置网卡 vim /etc/sysconfig/network-scripts/ifcfg-e ...

  10. Java NIO系列教程(十一) Pipe

    Java NIO 管道是2个线程之间的单向数据连接.Pipe有一个source通道和一个sink通道.数据会被写到sink通道,从source通道读取. 这里是Pipe原理的图示: 创建管道 通过Pi ...