【模板】 字典树

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 using namespace std;
 5 struct node{
 6     int cnt;  //记录出现次数
 7     int nex[30];//该节点下一个儿子的节点
 8 }trie[400500];
 9 char s1[105],s2[105];
10 int tot=1;//也可以0
11 void build(char* s){
12     int len=strlen(s);
13     int root=0;
14     for(int i=0;i<len;++i){
15         int id=s[i]-'a';
16         if(trie[root].nex[id]==0) trie[root].nex[id]=++tot;
17         root=trie[root].nex[id];
18         ++trie[root].cnt;
19     }
20 }
21 int query(char* s){
22     int len=strlen(s);
23     int root=0;
24     for(int i=0;i<len;++i){
25         int id=s[i]-'a';
26         if(!trie[root].nex[id]) return 0;
27         root=trie[root].nex[id];
28     }
29     return trie[root].cnt;
30 }
31 int main(){
32     while(gets(s1)){
33         int len=strlen(s1);
34         if(!len) break;
35         build(s1);
36     }
37     while(gets(s2)){
38         int u=query(s2);
39         printf("%d\n",u);
40     }
41     return 0;
42 }
43 //hdu1251
44 //https://vjudge.net/contest/281068#problem/C
45 //用gets不用scanf是因为读取字符串时,gets会舍弃回车,但scanf不会。
46 //https://www.cnblogs.com/hlongch/p/5742477.html

 

posted @ 2019-08-21 23:08  小布鞋  阅读(115)  评论(0编辑  收藏  举报