首页 > 其他 > 详细

LeetCode Implement Trie (Prefix Tree) (实现trie树3个函数:插入,查找,前缀)

时间:2015-07-16 00:46:16      阅读:737      评论:0      收藏:0      [点我收藏+]

 

 

技术分享

 

题意:实现trie树的3个功能,只含小写字母的串。

思路:老实做即可!

 

 

技术分享
 1 class TrieNode {
 2 public:
 3     TrieNode*  chd[26];
 4     bool flag;
 5     // Initialize your data structure here.
 6     TrieNode() {
 7         memset(chd,0,sizeof(chd));
 8         flag=0;
 9     }
10 
11 };
12 
13 class Trie {
14 public:
15     Trie() {
16         root = new TrieNode();
17     }
18 
19     // Inserts a word into the trie.
20     void insert(string word) {
21         int p=0;
22         TrieNode* tmp=root;
23         while(p<word.size())
24         {
25             if(!tmp->chd[word[p]-a])
26             {
27                 TrieNode* newnode=new TrieNode();
28                 tmp->chd[word[p]-a]=newnode;
29             }
30             tmp=tmp->chd[word[p]-a];
31             p++;
32         }
33         tmp->flag=1;
34     }
35 
36     // Returns if the word is in the trie.
37     bool search(string word) {
38         int p=0;
39         TrieNode* tmp=root;
40         while(p<word.size())
41         {
42             //cout<<word[p]<<" ";
43             if(tmp->chd[word[p]-a])    tmp=tmp->chd[word[p]-a];
44             else return false;
45             p++;
46         }
47         if(tmp->flag==1) return true;
48         return false;
49     }
50 
51     // Returns if there is any word in the trie
52     // that starts with the given prefix.
53     bool startsWith(string prefix) {
54         int p=0;
55         TrieNode* tmp=root;
56         while(p<prefix.size())
57         {
58             if(tmp->chd[prefix[p]-a])    tmp=tmp->chd[prefix[p]-a];
59             else return false;
60             p++;
61         }
62         return true;
63     }
64 
65 private:
66     TrieNode* root;
67 };
AC代码

 

LeetCode Implement Trie (Prefix Tree) (实现trie树3个函数:插入,查找,前缀)

原文:http://www.cnblogs.com/xcw0754/p/4649860.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!