F08【模板】AC自动机

视频链接:608【模板】AC自动机_哔哩哔哩_bilibili

 

Luogu P3808 【模板】AC 自动机(简单版)

#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>
using namespace std;

const int N=500010;
int n;char str[1000010];
int ch[N][26],cnt[N],idx;
int ne[N];

void insert(char *s){//建树
  int p=0;
  for(int i=0;s[i];i++){
    int j=s[i]-'a';
    if(!ch[p][j])ch[p][j]=++idx;
    p=ch[p][j];
  }
  cnt[p]++;
}
void build(){//建AC自动机
  queue<int> q;
  for(int i=0;i<26;i++)
    if(ch[0][i])q.push(ch[0][i]);
  while(q.size()){
    int u=q.front();q.pop();
    for(int i=0;i<26;i++){
      int v=ch[u][i];
      if(v)ne[v]=ch[ne[u]][i],q.push(v);
      else ch[u][i]=ch[ne[u]][i];
    }
  }
}
int query(char *s){
  int ans=0;
  for(int k=0,i=0;s[k];k++){
    i=ch[i][s[k]-'a'];
    for(int j=i;j&&~cnt[j];j=ne[j])
      ans+=cnt[j], cnt[j]=-1;
  }
  return ans;
}
int main(){
  cin>>n;
  for(int i=0;i<n; i++)
    cin>>str, insert(str);
  build();
  cin>>str;
  cout<<query(str)<<endl;
  return 0;
}

 

练习:

Luogu P3796 【模板】AC 自动机(加强版)

Luogu P5357 【模板】AC 自动机(二次加强版)

Luogu P2414 [NOI2011] 阿狸的打字机

Luogu P2444 [POI2000] 病毒

Luogu P2292 [HNOI2004] L 语言

Luogu P3966 [TJOI2013] 单词

Luogu P4052 [JSOI2007] 文本生成器

Luogu P3121 [USACO15FEB] Censoring G

 

posted @ 2022-04-16 09:33  董晓  阅读(1310)  评论(0编辑  收藏  举报