bzoj 2434: [Noi2011]阿狸的打字机
#include<cstdio>
#include<iostream>
#include<cstring>
#define M 100008
using namespace std;
char ch[M];
int cnt=,pos[M],now,fa[M],fail[M],q[M],head[M],next[M],u[M],cnt1,m,n;
int a[M][],head1[M],next1[M],u1[M],T,l[M],r[M],an[M],su[*M];
void build()
{
int h=,t=;
q[]=;
for(;h<t;)
{
int p=q[++h];
for(int i=;i<=;i++)
if(a[p][i])
{
int now=fail[p];
q[++t]=a[p][i];
for(;!a[now][i];now=fail[now]);
fail[a[p][i]]=a[now][i];
}
}
return;
}
void jia(int a1,int a2)
{
cnt1++;
u[cnt1]=a2;
next[cnt1]=head[a1];
head[a1]=cnt1;
return;
}
void dfs(int a1)
{
l[a1]=++T;
for(int i=head[a1];i;i=next[i])
dfs(u[i]);
r[a1]=++T;
}
int xun(int a1)
{
int sum=;
for(int i=a1;i;i-=i&-i)
sum+=su[i];
return sum;
}
void add(int a1,int a2)
{
for(int i=a1;i<=T;i+=i&-i)
su[i]+=a2;
}
int main()
{
scanf("%s",ch+);
now=;
n=strlen(ch+);
for(int i=;i<=n;i++)
if(ch[i]=='P')
{
pos[]++;
pos[pos[]]=now;
}
else if(ch[i]=='B')
now=fa[now];
else
{
if(!a[now][ch[i]-])
{
cnt++;
a[now][ch[i]-]=cnt;
fa[cnt]=now;
}
now=a[now][ch[i]-];
}
for(int i=;i<=;i++)
a[][i]=;
build();
for(int i=;i<=cnt;i++)
jia(fail[i],i);
scanf("%d",&m);
for(int i=;i<=m;i++)
{
int x,y;
scanf("%d%d",&x,&y);
u1[i]=x;
next1[i]=head1[y];
head1[y]=i;
}
dfs();
now=;
pos[]=;
for(int i=;i<=n;i++)
if(ch[i]=='P')
{
pos[]++;
for(int i=head1[pos[]];i;i=next1[i])
an[i]=xun(r[pos[u1[i]]])-xun(l[pos[u1[i]]]-);
}
else if(ch[i]=='B')
{
add(l[now],-);
now=fa[now];
}
else
{
now=a[now][ch[i]-];
add(l[now],);
}
for(int i=;i<=m;i++)
printf("%d\n",an[i]);
return ;
}
AC自动机 根据dfs序建立fail树(就是将失败指针反向),每次查询x子树中有多少y的节点。
bzoj 2434: [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序+树状 ...
- bzoj 2434 [Noi2011]阿狸的打字机 AC自动机
[Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4001 Solved: 2198[Submit][Status][D ...
- 【刷题】BZOJ 2434 [Noi2011]阿狸的打字机
Description 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机.打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母. 经阿狸研究发现,这个打字机是这样工作的 ...
- BZOJ 2434: [Noi2011]阿狸的打字机 AC自动机+fail树+线段树
Description 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机.打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母. 经阿狸研究发现,这个打字机是这样工作的 ...
- bzoj 2434 [Noi2011]阿狸的打字机(fail树+离线处理+BIT)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2434 [题意] 按照一定规则生成n个字符串,回答若干个询问:(x,y),问第x个字符串 ...
- BZOJ 2434 [Noi2011]阿狸的打字机(AC自动机)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2434 [题目大意] 给出一个打印的过程,'a'-'z'表示输入字母,P表示打印该字符串 ...
- bzoj 2434 [Noi2011]阿狸的打字机——AC自动机
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2434 dfs AC自动机,走过的点权值+1,回溯的时候权值-1:走到询问的 y 串的节点,看 ...
- ●BZOJ 2434: [Noi2011]阿狸的打字机
●赘述题目 (题意就不赘述了) ●解法: ●我先想的一个比较暴力的方法(要TLE): (ac自动机)先求出last数组(参见刘汝佳的解释:last[j]:表示j节点沿着失配指针往回走时,遇到的下一个单 ...
随机推荐
- JS 命名冲突
1. JS中全局变量和局部变量重名会导致在指定域内无法取到变量: 2. 取出的结果为undefined;
- spring中的Log4jConfigListener作用和webapp.root的设置
转:http://blog.sina.com.cn/s/blog_7bbf356c01016wld.html 使用spring中的Log4jConfigListener有如如下好处: 1. 动 ...
- 线程池的原理及实现 (zhuan)
http://blog.csdn.net/hsuxu/article/details/8985931 ************************************************* ...
- idea项目部署
idea新建项目: http://blog.csdn.net/wo541075754/article/details/46348135 详细 http://www.cnblogs.com/wql02 ...
- 什么是cname a记录
https://support.dnsimple.com/articles/cname-record/ CNAME就是别名记录,就是负责跳转,比如你给某个地址设置了一个cname,那当访问那个cnam ...
- js encodeURI方法认识
很早就知道js中encodeURI方法,也很早就用过,但是每次看到它总感觉有些陌生,因为不知道到底是什么原理,和普通的编码到底什么关系, 今天在查看w3c api时又遇到了她,正好有空就多看了几眼,突 ...
- dedecms 网站优化技巧
1.把列表文件中的<title>***</title>改为栏目名称-seo标题-网站名称即<title>{dede:field.title/}-{dede:fiel ...
- 【转】 C++的深拷贝与浅拷贝
对于普通类型的对象来说,它们之间的复制是很简单的,例如:int a=88;int b=a; 而类对象与普通对象不同,类对象内部结构一般较为复杂,存在各种成员变量.下面看一个类对象拷贝的简单例子. ...
- 将自定义的 service provider 绑定到 IOC 容器
首先要有一些类,可以自己自定义一些类放在app/目录下的自己新建的文件夹,在类里面实现代码逻辑 然后通过命令生成serviceprovider (php artisan make:provider ...
- js高级程序设计(四)变量、作用域和内存问题
基本类型和引用类型的值 ECMAScript 变量可能包含两种不同数据类型的值:基本类型值和引用类型值.基本类型值指的是 Undefined . Null . Boolean . Number 和 S ...