bzoj2555(后缀自动机+LCT)
题目描述
inline void link(int x,int y){
access(x);splay(x);access(y);splay(y);
f[x]=y;si[y]+=size[x];pushup(y);
}
然后cut长这样
inline void cut(int x,int y){
access(x);splay(x);
f[tr[x][]]=;tr[x][]=;
pushup(x);
}
所以在这颗LCT中,每个点的左儿子维护的是它的父亲,然后我们在算子树和的时候把左儿子扣掉就好了。
断断续续淦了三天,极菜。
#include<iostream>
#include<cstdio>
#include<cstring>
#define N 1300002
using namespace std;
int size[N],ch[N][],tr[N][],fa[N],si[N],last,cnt,n,l[N],q,f[N],val[N];
int mark;
char s[N],qs[];
inline void pushup(int x){size[x]=size[tr[x][]]+size[tr[x][]]+si[x]+val[x];}
inline bool ge(int x){return tr[f[x]][]==x;}
inline bool isroot(int x){return tr[f[x]][]!=x&&tr[f[x]][]!=x;}
inline void rotate(int x){
int y=f[x],o=ge(x);
if(isroot(x))return;
tr[y][o]=tr[x][o^];f[tr[y][o]]=y;
if(!isroot(y))tr[f[y]][ge(y)]=x;f[x]=f[y];
f[y]=x;tr[x][o^]=y;pushup(y);pushup(x);
}
inline void splay(int x){
while(!isroot(x)){
int y=f[x];
if(isroot(y))rotate(x);
else rotate(ge(x)==ge(y)?y:x),rotate(x);
}
}
inline void access(int x){
for(int y=;x;y=x,x=f[x]){
splay(x);
si[x]+=size[tr[x][]];si[x]-=size[y];tr[x][]=y;
pushup(x);
}
}
inline void link(int x,int y){
access(x);splay(x);access(y);splay(y);
f[x]=y;si[y]+=size[x];pushup(y);
}
inline void cut(int x,int y){
access(x);splay(x);
f[tr[x][]]=;tr[x][]=;
pushup(x);
}
void Decode(char *ch,int mask){
int l=strlen(ch+);
for(int i=;i<l;++i){
mask=(mask*+i)%l;
swap(ch[i+],ch[mask+]);
}
}
inline void ins(int x){
int p=last,np=++cnt;last=np;l[np]=l[p]+;size[np]=val[np]=;
for(;p&&!ch[p][x];p=fa[p])ch[p][x]=np;
if(!p)fa[np]=,link(np,);
else{
int q=ch[p][x];
if(l[p]+==l[q])fa[np]=q,link(np,q);
else{
int nq=++cnt;l[nq]=l[p]+;
memcpy(ch[nq],ch[q],sizeof(ch[q]));
int y=fa[q];cut(q,y);link(nq,y);
fa[nq]=fa[q];fa[q]=fa[np]=nq;
link(q,nq);link(np,nq);
for(;ch[p][x]==q;p=fa[p])ch[p][x]=nq;
}
}
}
int query(int n){
int now=;
for(int i=;i<=n;++i)if(ch[now][s[i]-'A'])now=ch[now][s[i]-'A'];else return ;
access(now);splay(now);
return size[now]-size[tr[now][]];
}
int main(){
scanf("%d",&q);
scanf("%s",s+);n=strlen(s+);last=cnt=;
for(int i=;i<=n;++i)ins(s[i]-'A');
while(q--){
scanf("%s",qs);scanf("%s",s+);n=strlen(s+);
Decode(s,mark);
if(qs[]=='Q'){
int x=query(n);mark^=x;printf("%d\n",x);
}
else for(int i=;i<=n;++i)ins(s[i]-'A');
}
return ;
}
bzoj2555(后缀自动机+LCT)的更多相关文章
- BZOJ2555 SubString 【后缀自动机 + LCT】
题目 懒得写背景了,给你一个字符串init,要求你支持两个操作 (1):在当前字符串的后面插入一个字符串 (2):询问字符串s在当前字符串中出现了几次?(作为连续子串) 你必须在线支持这些操作. 输入 ...
- 51nod 1600 Simple KMP【后缀自动机+LCT】【思维好题】*
Description 对于一个字符串|S|,我们定义fail[i],表示最大的x使得S[1..x]=S[i-x+1..i],满足(x<i) 显然对于一个字符串,如果我们将每个0<=i&l ...
- bzoj 2555 SubString —— 后缀自动机+LCT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2555 建立后缀自动机,就可以直接加入新串了: 出现次数就是 Right 集合的大小,需要查询 ...
- bzoj 2555: SubString【后缀自动机+LCT】
一直WA--找了半天错的发现居然是解密那里的mask其实是不能动的--传进去的会变,但是真实的那个不会变-- 然后就是后缀自动机,用LCT维护parent树了--注意不能makeroot,因为自动机的 ...
- 【BZOJ2555】SubString 后缀自动机+LCT
[BZOJ2555]SubString Description 懒得写背景了,给你一个字符串init,要求你支持两个操作 (1):在当前字符串的后面插入一个字符串 (2 ...
- BZOJ2555 SubString【后缀自动机+LCT】
Description 懒得写背景了,给你一个字符串init,要求你支持两个操作 (1):在当前字符串的后面插入一个字符串 (2):询问字符串s在当前字符串中出现了几次?(作为连续子串) 你必须在线支 ...
- BZOJ2555 SubString(后缀自动机+LCT)
询问串放在SAM上不跳fail跑到的节点的|right|即为答案.用LCT维护parent树即可.可以直接维护子树信息,也可以转化为路径加.注意强制在线所使用的mask是作为参数传进去的. #incl ...
- 【BZOJ4545】DQS的trie 后缀自动机+LCT
[BZOJ4545]DQS的trie Description DQS的自家阳台上种着一棵颗粒饱满.颜色纯正的trie. DQS的trie非常的奇特,它初始有n0个节点,n0-1条边,每条边上有一个字符 ...
- bzoj 2555: SubString 后缀自动机+LCT
2555: SubString Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 688 Solved: 235[Submit][Status][Dis ...
随机推荐
- node笔记
基础入门可参考: <一起学 Node.js>—— https://github.com/nswbmw/N-blog 核心模块使用前需要引入 let fs=require('fs'); ...
- [编程笔记]第二章 C语言预备知识
/*第二讲 C语言预备专业知识 1.CPU 内存条 硬盘 显卡 主板 显示器之间的关系 CPU不能直接处理硬盘上的数据 文件存储在硬盘,当运行时,操作系统把硬盘上的数据调用到内存条上. 图像以数据的形 ...
- MySQL unknown variable 'default-character-set=utf8'的解决
Windows07 安装了MySQL-server-5.5,直接在命令行输入net start mysql ,启动mysql成功, 然后修改/MySQL Server 5.5/my.ini,增加了de ...
- python爬虫之requests的基本使用
简介 Requests是用python语言基于urllib编写的,采用的是Apache2 Licensed开源协议的HTTP库,Requests它会比urllib更加方便,可以节约我们大量的工作. 一 ...
- python之路--类的约束, 异常处理, MD5, 日志处理
一 . 类的约束 1. 写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError class Base: # 对子类进行了约束. 必须重写该方法 # 以后上班了. 拿到公司代 ...
- Delphi 在dbgrideh中表格输入数据时有效性的检查(转)
在数据库系统设计中经常要用到在表格中进行数据录入,如何判断在数据导入时的数据有效性呢?下面介绍几种常用的方法与大家交流. 方法一:Dbgrid是与Table,在Table的Column的OnSetTe ...
- Python——Flask框架——数据库
一.数据库框架 Flask-SQLAlchemy (1)安装: pip install flask-sqlalchemy (2)Flask-SQLAlchemy数据库URL 数据库引擎 URL MyS ...
- Military Problem CodeForces 1006E (dfs序)
J - Military Problem CodeForces - 1006E 就是一道dfs序的问题 给定一个树, 然后有q次询问. 每次给出u,k, 求以u为根的子树经过深搜的第k个儿子,如果一个 ...
- Nginx http keepalive针对客户端行为指令
keepalive 描述 多个http请求可以复用Tcp链接 减少握手次数 通过减少并发连接数减少服务器资源消耗 降低Tcp拥塞控制影响 Syntax: keepalive_disable none ...
- BZOJ2521[Shoi2010]最小生成树——最小割
题目描述 Secsa最近对最小生成树问题特别感兴趣.他已经知道如果要去求出一个n个点.m条边的无向图的最小生成树有一个Krustal算法和另一个Prim的算法.另外,他还知道,某一个图可能有多种不同的 ...