HDU 2222 AC自动机(模版题)

Keywords Search

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)
Total Submission(s): 70290    Accepted Submission(s): 23917


Problem Description
In the modern time, Search engine came into the life of everybody like Google, Baidu, etc.
Wiskey also wants to bring this feature to his image retrieval system.
Every image have a long description, when users type some keywords to find the image, the system will match the keywords with description of image and show the image which the most keywords be matched.
To simplify the problem, giving you a description of image, and some keywords, you should tell me how many keywords will be match.
 

 

Input
First line will contain one integer means how many cases will follow by.
Each case will contain two integers N means the number of keywords and N keywords follow. (N <= 10000)
Each keyword will only contains characters 'a'-'z', and the length will be not longer than 50.
The last line is the description, and the length will be not longer than 1000000.
 

 

Output
Print how many keywords are contained in the description.
 

 

Sample Input
1 5 she he say shr her yasherhs
 

 

Sample Output
3
 

 

Author
Wiskey
 

 

Recommend
lcy   |   We have carefully selected several similar problems for you:  2896 3065 2243 2825 3341 
 

题意:给出一个字典和一个模式串,问模式串中出现几个字典中的单词

代码:

  1 ////#include "bits/stdc++.h"
  2 #include "cstdio"
  3 #include "map"
  4 #include "set"
  5 #include "cmath"
  6 #include "queue"
  7 #include "vector"
  8 #include "string"
  9 #include "cstring"
 10 #include "time.h"
 11 #include "iostream"
 12 #include "stdlib.h"
 13 #include "algorithm"
 14 #define db double
 15 #define ll long long
 16 //#define vec vector<ll>
 17 #define Mt  vector<vec>
 18 #define ci(x) scanf("%d",&x)
 19 #define cd(x) scanf("%lf",&x)
 20 #define cl(x) scanf("%lld",&x)
 21 #define pi(x) printf("%d\n",x)
 22 #define pd(x) printf("%f\n",x)
 23 #define pl(x) printf("%lld\n",x)
 24 #define rep(i, x, y) for(int i=x;i<=y;i++)
 25 const int N   = 1e6 + 5;
 26 const int mod = 1e9 + 7;
 27 const int MOD = mod - 1;
 28 const db  eps = 1e-18;
 29 const db  PI  = acos(-1.0);
 30 using namespace std;
 31 const int M = 26;
 32 queue<int> q;
 33 vector<string> vec;
 34 bool vis[N];
 35 struct Trie {
 36     int trieN;
 37     int ch[N][M], val[N], fail[N];
 38     void init() {
 39         memset(vis,0,sizeof(vis));
 40         trieN = -1;
 41         newnode();
 42     }
 43     int newnode() {
 44         memset(ch[++trieN], 0, sizeof(ch[0]));
 45         val[trieN] = fail[trieN] = 0;
 46         return trieN;
 47     }
 48     void insert(const string &str, int index) {
 49         int cur = 0;
 50         for (int i = 0;str[i];i++) {
 51             int d = str[i] - 'a';
 52             if (!ch[cur][d])
 53                 ch[cur][d] = newnode();
 54             cur = ch[cur][d];
 55         }
 56         if (val[cur]) vis[index] = 1;
 57         else val[cur] = index;
 58     }
 59     void build() {
 60         for (int i = 0;i < M;i++) {
 61             if (ch[0][i])
 62                 q.push(ch[0][i]);
 63         }
 64         while (!q.empty()) {
 65             int cur = q.front(); q.pop();
 66             for (int i = 0;i < M;i++) {
 67                 int &next = ch[cur][i];
 68                 if (next) {
 69                     fail[next] = ch[fail[cur]][i];
 70                     q.push(next);
 71                 }
 72                 else next = ch[fail[cur]][i];
 73             }
 74         }
 75     }
 76     void query(const string &str) {
 77         int cur = 0, tmp;
 78         for (int i = 0;str[i];i++) {
 79             int d = str[i] - 'a';
 80             tmp = cur = ch[cur][d];
 81             while (tmp && ~val[tmp]) {
 82                 if (val[tmp] != -1) vis[val[tmp]] = 1;
 83                 val[tmp] = -1;
 84                 tmp = fail[tmp];
 85             }
 86         }
 87     }
 88 }ac;
 89 
 90 int main(){
 91     ios::sync_with_stdio(false);
 92     cin.tie(0);
 93     int t;
 94     cin >> t;
 95     while(t--){
 96         ac.init();   //初始化
 97         int n;
 98         string str;
 99         cin >> n;
100         vec.resize(n+1);
101         for(int i = 1;i <= n;i++){
102             cin >> vec[i];
103             ac.insert(vec[i],i);
104         }
105         ac.build();
106         cin>>str;
107         ac.query(str);   //查询是否在str里出现过
108         int ans=0;
109         for(int i = 1;i <= n;i++){
110             if (vis[i]) ans++;
111         }
112         pi(ans);
113     }
114     return 0;
115 }

 

posted @ 2017-12-09 09:57  thges  阅读(191)  评论(0编辑  收藏  举报