[NOI2011]阿狸打字机
- 题意:一开始是个空串s,有三种操作:(1.末尾加一个字符 2.末尾减一个字符 3.存储该字符串)
- 思路:
一开始在trie树上动态加点很好处理,3操作的时候记录一下此时trie树上的pos,同时记录dep,fa后面有用。
建AC自动机,因为这道题的大致思路还是:y包含于x,则x的所有前缀(trie树上的祖先节点)对应的后缀中存在y的个数和。
因此只要y的祖先节点在fail树上对应++。然后再算x的子树和。(这里映射到dfs序上,显然树状数组维护,我一开始tm写了线段树)
询问先按y排序,这样就可以O(|S|)跳串,具体我是ylst和y往LCA(ylst,y)上跳。过程中ylst删除贡献,y加入贡献。
我加快读,O2跑到了第一页:
- code:
#include<bits/stdc++.h>
using namespace std;
const int N=1e6+5;
char s[N];
int sz,n,m,pos[N],ans[N];
struct query {int x,y,id;}Q[N];
bool cmp(query u,query v) {return u.y<v.y;}
static char buf[1000000],*p1=buf,*p2=buf,obuf[1000000],*p3=obuf;
#define getchar() p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?EOF:*p1++
#define putchar(x) (p3-obuf<1000000)?(*p3++=x):(fwrite(obuf,p3-obuf,1,stdout),p3=obuf,*p3++=x)
template<typename item>
inline void read(register item &x)
{
x=0;register char c=getchar();
while(c<'0'||c>'9')c=getchar();
while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+(c^48),c=getchar();
}
struct AC {
int c[N],fa[N],fail[N],go[N][27],nw,nd,Q[N],hd,tl,nxt[N],to[N],head[N],ecnt,In[N],Out[N],dep[N],Time,y0,rt;
void Update(int x,int d) {for(;x<=Time;x+=x&(-x))c[x]+=d;}
int Sum(int x) {int res=0;for(;x;x-=x&(-x))res+=c[x];return res;}
AC() {nw=nd=tl=Time=y0=0;hd=1;}
void add_edge(int u,int v) {nxt[++ecnt]=head[u];to[ecnt]=v;head[u]=ecnt;}
void Add(int x) {if(!go[nw][x]){go[nw][x]=++nd;fa[nd]=nw;dep[nd]=dep[nw]+1;}nw=go[nw][x];}
void Del() {nw=fa[nw];}
void Get(int &p) {p=nw;}
void init(int u) {
In[u]=++Time;
for(int i=head[u];i;i=nxt[i]) {
int v=to[i];init(v);
}
Out[u]=Time;
}
void gt_fail() {
for(int j=0;j<26;j++)if(go[0][j])Q[++tl]=go[0][j];
while(hd<=tl) {
int u=Q[hd++];
for(int j=0;j<26;j++) {
int v=go[u][j];
if(v) fail[v]=go[fail[u]][j],Q[++tl]=v;
else go[u][j]=go[fail[u]][j];
}
}
for(int i=1;i<=nd;i++) add_edge(fail[i],i);
// for(int i=1;i<=nd;i++) printf("+ %d %d\n",fail[i],i);
init(0);
}
void solve(int id,int x,int y) {
int lst=y;
while(y!=y0) {
if(dep[y]>dep[y0]) {Update(In[y],1);y=fa[y];}
else {Update(In[y0],-1);y0=fa[y0];}
//y0 used to add lca(y,y0)
}
ans[id]=Sum(Out[x])-Sum(In[x]-1);
y0=lst;
}
}A;
int main() {
// freopen("dd.in","r",stdin);
char c;
while((c=getchar())!='\n') {
if(c=='P') {++n;A.Get(pos[n]);}
else if(c=='B') A.Del();
else A.Add(c-'a');
}
A.gt_fail();
read(m);
for(int i=1;i<=m;i++) read(Q[i].x),read(Q[i].y),Q[i].id=i;
sort(Q+1,Q+1+m,cmp);
for(int i=1;i<=m;i++) {A.solve(Q[i].id,pos[Q[i].x],pos[Q[i].y]);}
for(int i=1;i<=m;i++) printf("%d\n",ans[i]);
return 0;
}
[NOI2011]阿狸打字机的更多相关文章
- BZOJ 2434: [Noi2011]阿狸的打字机 [AC自动机 Fail树 树状数组 DFS序]
2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 2545 Solved: 1419[Submit][Sta ...
- BZOJ 2434: [Noi2011]阿狸的打字机( AC自动机 + DFS序 + 树状数组 )
一个串a在b中出现, 那么a是b的某些前缀的后缀, 所以搞出AC自动机, 按fail反向建树, 然后查询(x, y)就是y的子树中有多少是x的前缀. 离线, 对AC自动机DFS一遍, 用dfs序+树状 ...
- [NOI2011]阿狸的打字机(好题!!!!)
2785: [NOI2011]阿狸的打字机 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 7 Solved: 3[Submit][Status][We ...
- P2414 [NOI2011]阿狸的打字机
P2414 [NOI2011]阿狸的打字机 AC自动机+树状数组 优质题解 <------题目分析 先AC自动机搞出Trie图 然后根据fail指针建一只新树 把树映射(拍扁)到一个序列上,用树 ...
- 【BZOJ2434】[NOI2011]阿狸的打字机 AC自动机+DFS序+树状数组
[BZOJ2434][NOI2011]阿狸的打字机 Description 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机.打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P ...
- [NOI2011]阿狸的打字机 --- AC自动机 + 树状数组
[NOI2011] 阿狸的打字机 题目描述: 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机. 打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母.经阿狸研究发现, ...
- BZOJ2434 [Noi2011]阿狸的打字机 【AC自动机 + fail树 + 树状数组】
2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MB Submit: 3610 Solved: 1960 [Submit][S ...
- BZOJ2434: [NOI2011]阿狸的打字机(AC自动机+dfs序+树状数组)
[NOI2011]阿狸的打字机 题目链接:https://www.luogu.org/problemnew/show/P2414 题目背景 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机. ...
- bzoj 2434 [Noi2011]阿狸的打字机 AC自动机
[Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4001 Solved: 2198[Submit][Status][D ...
随机推荐
- android 布局的android:padding 和android:margin的区别
android:layout_marginLeft指该控件距离边父控件的边距, android:paddingLeft指该控件内部内容,如文本距离该控件的边距. 如: 当按钮分别设置以上两个属性时,得 ...
- 关于 video 播放的新探索
前端同学要使用 HTML5 播放器视频,必然会使用 video 标签,不过大多数同学只是使用了较简单的功能,其实它本身拥有不凡之力有待我们发现. 首先,我们先来看下 video 最基础的用法: 使用 ...
- spark-shell报错java.lang.IllegalArgumentException: java.net.UnknownHostException: namenode
在使用spark on yarn启动spark-shell时,发现报错: 是说找不到主机名为namenode的主机,那么应该是配置文件出错了. 经过检查,发现是spark-defaults.conf文 ...
- Paxos算法的一个简单小故事
一.Paxos是什么? Paxos,它是一个基于消息传递的一致性算法,Leslie Lamport在1990年提出,近几年被广泛应用于分布式计算中,Google的Chubby,Apache的Zooke ...
- ssm项目框架搭建(增删改查案例实现)——(SpringMVC+Spring+mybatis项目整合)
Spring 常用注解 内容 一.基本概念 1. Spring 2. SpringMVC 3. MyBatis 二.开发环境搭建 1. 创建 maven 项目 2. SSM整合 2.1 项目结构图 2 ...
- 集合框架基础三——Map
Map接口 * 将键映射到值的对象 * 一个映射不能包含重复的键 * 每个键最多只能映射到一个值 Map接口和Collection接口的不同 * Map是双列的,Collection是单列的 * ...
- 引用nodejs的url模块实现url路由功能
我们在本地创建服务器之后需要写不同的后缀名来访问同一个站点的不同页面,如果不实现路由功能.则每次访问localhost:3000 不论后面写什么 比如localhost:3000/index.loc ...
- 【Unity原神AR开发实战 2022】下载原神模型,PMX转FBX,导入到Unity,AR设置,测试应用程序,生成应用程序
文章目录 一.前言 二.模型下载 1.官网下载 2.模之屋官方下载 3.第三方链接 三.pmx转fbx 1.Blender插件CATS的下载与安装 2.pmx模型的导入 四.Unity开发部分 1.V ...
- ASP.NET Core的几种服务器类型[共6篇]
作为ASP.NET CORE请求处理管道的"龙头"的服务器负责监听和接收请求并最终完成对请求的响应.它将原始的请求上下文描述为相应的特性(Feature),并以此将HttpCont ...
- 华为组播实验,PIM-DM组播实验
一.配置VLAN,并将端口加入VLAN LSW5: system vlan batch 10 to 100 int g 0/0/1 port link-type trunk port trunk al ...