后缀数组或者AC自动机都可以,模板题。

/**************************************************************
Problem: 3172
User: BLADEVIL
Language: C++
Result: Accepted
Time:424 ms
Memory:34260 kb
****************************************************************/ //By BLADEVIL
#include <cstdio>
#include <cstring>
#define maxn 2000010
#define maxm 300 using namespace std; struct node{
int cnt;
node *fail,*child[];
node(){
cnt=; fail=NULL;
memset(child,,sizeof child);
}
} *que[maxn],*root=new(node),*w[maxm]; int n; int main(){
scanf("%d",&n);
for (int i=;i<=n;i++){
char c[maxn];
scanf("%s",&c);
int len=strlen(c);
node *t=root;
for (int j=;j<len;j++){
if (!t->child[c[j]-'a']) t->child[c[j]-'a']=new(node);
t=t->child[c[j]-'a']; t->cnt++;
}
w[i]=t;
}
int h=,t=;
root->fail=root; que[]=root;
while (h<t){
node *u=que[++h];
for (int i=;i<;i++) if (u->child[i]){
que[++t]=u->child[i];
node *v=u->fail;
que[t]->fail=v->child[i]&&v->child[i]!=que[t]?v->child[i]:root;
} else u->child[i]=u->fail->child[i];
}
for (int i=t;i;i--) que[i]->fail->cnt+=que[i]->cnt;
for (int i=;i<=n;i++) printf("%d\n",w[i]->cnt);
return ;
}
/**************************************************************
Problem: 3172
User: BLADEVIL
Language: C++
Result: Accepted
Time:6660 ms
Memory:107360 kb
****************************************************************/
//By BLADEVIL
#include <cstdio>
#include <cstring>
#include <algorithm>
#define maxn 1001000
#define maxm 300 using namespace std; int n,len;
char s[maxn];
int sa[maxn],tsa[maxn],rk[maxn],trk[maxn],sum[maxn],h[maxn];
int w[maxn][];
int adr[maxm],len_s[maxm]; inline void getsa(int j) {
for (int i=;i<=len;i++) sum[i]=;
for (int i=;i<=len;i++) sum[rk[i+j]]++;
for (int i=;i<=len;i++) sum[i]+=sum[i-];
for (int i=len;i;i--) tsa[sum[rk[i+j]]--]=i; for (int i=;i<=len;i++) sum[i]=;
for (int i=;i<=len;i++) sum[rk[i]]++;
for (int i=;i<=len;i++) sum[i]+=sum[i-];
for (int i=len;i;i--) sa[sum[rk[tsa[i]]]--]=tsa[i];
} inline int query(int l,int r) {
int i,j;
for (i=,j=;(j<<)<=r-l+;j<<=,i++) ;
return min(w[l][i],w[r-j+][i]);
} int main() {
scanf("%d",&n); len=;
for (int i=;i<=n;i++) {
scanf("%s",s+len+);
adr[i]=len+;
len=strlen(s+);
s[++len]='^';
len_s[i]=len-adr[i];
}
//for (int i=1;i<=len;i++) printf("%c",s[i]); printf("\n");
for (int i=;i<=len;i++) sum[s[i]]++;
for (int i=;i<=;i++) sum[i]+=sum[i-];
for (int i=len;i;i--) sa[sum[s[i]]--]=i;
rk[sa[]]=;
for (int i=,p=;i<=len;i++) {
if (s[sa[i]]!=s[sa[i-]]) p++;
rk[sa[i]]=p;
}
for (int j=;j<=len;j<<=) {
getsa(j);
trk[sa[]]=;
for (int i=,p=;i<=len;i++) {
if (rk[sa[i]]!=rk[sa[i-]]||rk[sa[i]+j]!=rk[sa[i-]+j]) p++;
trk[sa[i]]=p;
}
for (int i=;i<=len;i++) rk[i]=trk[i];
}
for (int i=,j=;i<=len;i++) {
if (rk[i]==) continue;
while (i+j<=len&&sa[rk[i]-]+j<=len&&s[i+j]==s[sa[rk[i]-]+j]) j++;
h[rk[i]]=j;
if (j) j--;
}
//for (int i=1;i<=len;i++) printf("%d ",sa[i]); printf("\n");
//for (int i=1;i<=len;i++) printf("%d ",h[i]); printf("\n");
memset(w,,sizeof w);
for (int i=;i<=len;i++) w[i][]=h[i];
for (int j=,k=;j<;j++,k<<=)
for (int i=;i<=len;i++)
if (i+k<=len) w[i][j]=min(w[i][j-],w[i+k][j-]);
//for (int i=1;i<=len;i++) printf("%d ",w[i][2]); printf("\n");
//printf("%d\n",query(5,8));
//printf("%d\n",rk[6]);
for (int i=;i<=n;i++) {
int l=,r=rk[adr[i]],mid,left=rk[adr[i]],right=rk[adr[i]];
while (l<=r) {
mid=l+r>>;
if (query(mid+,rk[adr[i]])>=len_s[i])
left=mid,r=mid-; else l=mid+;
}
l=rk[adr[i]],r=len;
while (l<=r) {
mid=l+r>>;
if (query(rk[adr[i]]+,mid)>=len_s[i])
right=mid,l=mid+; else r=mid-;
}
printf("%d\n",right-left+);
}
return ;
}

bzoj 3172 后缀数组|AC自动机的更多相关文章

  1. BZOJ 3172: [Tjoi2013]单词 [AC自动机 Fail树]

    3172: [Tjoi2013]单词 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 3198  Solved: 1532[Submit][Status ...

  2. BZOJ 3172 单词(ac自动机)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=3172 题意:给出n个单词.输出每个单词在所有单词中一共出现多少次? 思路:首先将所有单词 ...

  3. bzoj 3172: [Tjoi2013]单词 AC自动机

    3172: [Tjoi2013]单词 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  4. BZOJ 3172 [Tjoi2013]单词 AC自动机Fail树

    题目链接:[http://www.lydsy.com/JudgeOnline/problem.php?id=3172] 题意:给出一个文章的所有单词,然后找出每个单词在文章中出现的次数,单词用标点符号 ...

  5. 【字符串】BZOJ上面几个AC自动机求最为字串出现次数的题目

    (一下只供自己复习用,目的是对比这几个题,所以写得不详细.需要细节的可以参考其他博主) [BZOJ3172:单词] 题目: 某人读论文,一篇论文是由许多(N)单词组成.但他发现一个单词会在论文中出现很 ...

  6. BZOJ.2938.[POI2000]病毒(AC自动机)

    题目链接 \(Description\) 给n个模式串,问是否存在长度无限的主串,使得任何一个模式串都没有在主串中出现. \(Solution\) 先建AC自动机. 假设我们有了一个无限长的安全代码, ...

  7. bzoj 1398: 寻找主人 AC自动机+最小表示法

    题目大意: 给定两个序列判断是否循环同构,若循环同构则输出最小表示 题解: 因为没有样例输入输出,一开始没看到要求输出最小表示 Wa一大页. 但不得不说bzoj还是挺高效的: 赞一个 XD.jpg 判 ...

  8. bzoj 3881: [Coci2015]Divljak AC自动机

    题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3881 题解: 这道题我想出了三种做法,不过只有最后一种能过. 第一种: 首先我们把所有的 ...

  9. BZOJ 4516 后缀数组+ST+set

    写了一半 没了啊啊啊 重新写的 思路: 先不考虑后缀自动机 (我不会啊) 那这道题只能用后缀数组了 先把原串倒一下 后缀->前缀 相当于每回在前面加了一个字母 求不同的子串个数 首先 正常的求子 ...

随机推荐

  1. 数据结构Java实现07----队列:顺序队列&顺序循环队列、链式队列、顺序优先队列

    一.队列的概念: 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在其一端进行插入操作在其 ...

  2. C# explicit与implicit

    1.它们解决什么问题? 考虑下面的需求,Person类有个字段age.我想使用Person p = (Person) 18 来创建一个age为18的Person对象,怎么办? 更进一步,我想使用Per ...

  3. C++基础笔记(三)C++面向对象

    C++类 C++类与结构体类似 定义 class 类名{ <成员定义>; ........ }; 文件格式 *.mm 支持 C/C++ *.cpp C++源文件 *.h C++头文件   ...

  4. Windows系统安装Oracle 11g数据库

    一.下载 http://www.oracle.com/technetwork/database/enterprise-edition/downloads/index.html以下两网址来源此官方下载页 ...

  5. ZGrapher 画函数曲线图的工具

    可以下载个绿色版,我下载的是 ZGrapher 1.4 绿色版.下面先看下图出来的图: 然后可以在“file"->"Save as Picture ..." -&g ...

  6. [转] 腾讯云直播OBS推流教程

    from: http://www.jianshu.com/p/bf4066028882 腾讯云直播OBS推流教程 字数383 阅读55 评论3 喜欢0 1.安装OBS 进入obs 官网 : https ...

  7. js正则匹配只能输入有效数字可加小数点

    var reg = /^\d+\.?\d*$/; if(value.search(/^\d+\.?\d*$/)===0 && parseFloat(value)>0){//只能输 ...

  8. shell+curl监控网站页面(域名访问状态),并利用sedemail发送邮件

    应领导要求,对公司几个主要站点的域名访问情况进行监控.下面分享一个监控脚本,并利用sendemail进行邮件发送. 监控脚本如下:下面是写了一个多线程的网站状态检测脚本,直接从文件中读出站点地址,然后 ...

  9. 由索引节点(inode)爆满引发的问题

    关于磁盘空间中索引节点爆满的问题还是挺多的,借此跟大家分享一下: 一.发现问题在公司一台配置较低的Linux服务器(内存.硬盘比较小)的/data分区内创建文件时,系统提示磁盘空间不足,用df -h命 ...

  10. C# winform版 nbtstat

    参考:http://www.cnblogs.com/geqinggao/archive/2013/01/21/2869644.html 一.nbtstat命令 显示基于 TCP/IP 的 NetBIO ...