hdu 2222 Keywords Search(ac自动机)
2015-08-22 16:40
399 查看
题意:求目标串中出现了几个模式串
思路:ac自动机
View Code
思路:ac自动机
#include<iostream> #include<stdio.h> #include<string.h> #include<queue> using namespace std; struct Trie{ int next[500010][26],fail[500010],end[500010]; int root,L; int newnode(){ for(int i=0;i<26;i++) next[L][i]=-1; end[L++]=0; return L-1; } void init(){ L=0; root=newnode(); } void insert(char buf[]){ int len=strlen(buf); int now=root; for(int i=0;i<len;i++){ if(next[now][buf[i]-'a']==-1) next[now][buf[i]-'a']=newnode(); now=next[now][buf[i]-'a']; } end[now]++; } void build(){ queue<int>Q; fail[root]=root; for(int i=0;i<26;i++) if(next[root][i]==-1) next[root][i]=root; else{ fail[next[root][i]]=root; Q.push(next[root][i]); } while(!Q.empty()){ int now=Q.front(); Q.pop(); for(int i=0;i<26;i++) if(next[now][i]==-1) next[now][i]=next[fail[now]][i]; else{ fail[next[now][i]]=next[fail[now]][i]; Q.push(next[now][i]); } } } int query(char buf[]){ int len=strlen(buf); int now=root; int res=0; for(int i=0;i<len;i++){ now=next[now][buf[i]-'a']; int temp=now; while(temp!=root){ res+=end[temp]; end[temp]=0; temp=fail[temp]; } } return res; } void debug(){ for(int i=0;i<L;i++){ printf("id = %3d,fail = %3d,end = %3d,chi = [",i,fail[i],end[i]); for(int j=0;j<26;j++) printf("%2d",next[i][j]); printf("]\n"); } } }; char buf[1000010]; Trie ac; int main(){ int T; int n; scanf("%d",&T); while(T--){ scanf("%d",&n); ac.init(); for(int i=0;i<n;i++){ scanf("%s",buf); ac.insert(buf); } ac.build(); scanf("%s",buf); printf("%d\n",ac.query(buf)); } return 0; }
View Code
相关文章推荐
- [转]执行mount命令时找不到介质或者mount:no medium found的解决办法
- TCP UDP简介
- viewpager 与 pageradapter
- 沿对角线方向打印数组
- C源码@数据结构与算法->PriorityQueues
- poj2886线段树(单点修改,区间查询)
- zoj Little Keng(快速幂)
- hdu4911 Inversion
- 0824Android基础CheckBox+ImageView+ListView
- 算菜价
- 恩布企业IM PC端,服务端发布 1.17 版本
- Matlab将图像转换成GIF
- CSS浮动的处理
- POJ C++程序设计 编程题#1 编程作业—运算符重载
- 牛客_{}大括号里面的内容都会执行,如果它不是成员函数的时候,看成是构造函数中的方法;
- 静态工厂方法讲解
- 面试精选逻辑推理题总结
- LeetCode2.1.10(4Sum)
- Romantic(hdu 2669)
- DNS域传送信息泄露