码迷,mamicode.com
首页 > 其他好文 > 详细

Trie树

时间:2016-05-23 10:35:56      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:

很多时候以为自己能记得做过的题目,可是实际上做过了几乎就不记得了。。。。。。。sad,于是还是记录一下吧。

 

题目:

对于小Hi的每一个询问,输出一个整数Ans,表示词典中以小Hi给出的字符串为前缀的单词的个数。

样例输入

5
babaab
babbbaaaa
abba
aaaaabaa
babaababb
5
babb
baabaaa
bab
bb
bbabbaab

算法:
记录一个Trie树,trie树的struct的内容包括,节点的内容,Trie *next[26],因为有26个字母,一个ans记录访问过的次数。

分为两步,1:依次读取每条字符串,记录节点,若节点数据为null则记录,对于每个字符cnt++。
2.判断出现的次数,直接依次读取,知道访问到了那个节点,得到节点的cnt.

实现:
 1 #include <iostream>
 2 #include <string>
 3 #include <cstring>
 4 #include <cmath>
 5 using namespace std;
 6 const int MAXN=105;
 7 
 8 struct Trie{
 9     char ch;
10     int cnt;
11     Trie *next[26];
12     Trie(){
13         cnt=0;
14         for(int i=0;i<26;i++){
15             next[i]=NULL;
16         }
17    }
18 };
19 Trie root;
20 int ans;
21 void insertWord(char *str){
22     int len=strlen(str);
23     Trie *head=&root;
24     for(int i=0;i<len;i++){
25         int idx=str[i]-a;
26         if(head->next[idx]==NULL){
27         Trie * node=new Trie;
28         node->ch=str[i];
29             head->next[idx]=node;
30         }
31         head=head->next[idx];
32         head->cnt++;
33         
34     }
35 }
36 void queryWord(char *str){
37     Trie* head=&root;
38     int len=strlen(str);
39     ans=0;
40     for(int i=0;i<len;i++){
41         int idx=str[i]-a;
42         if(head->next[idx]==NULL)return ;
43         else{
44             head=head->next[idx];
45         }
46     }
47     ans=head->cnt;
48 }
49 int main(int argc, const char * argv[]) {
50     char str[MAXN];
51     int n,m;
52     cin>>n;
53     for(int i=0;i<n;i++){
54         cin>>str;
55         insertWord(str);
56     }
57     cin>>m;
58     for(int i=0;i<m;i++){
59         cin>>str;
60         ans=0;
61         queryWord(str);
62         cout<<ans<<endl;
63     }
64 }

 



Trie树

标签:

原文地址:http://www.cnblogs.com/bounceFront/p/5518880.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!