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

LeetCode OJ:Add and Search Word - Data structure design(增加以及搜索单词)

时间:2015-11-20 22:59:27      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:

Design a data structure that supports the following two operations:

void addWord(word)
bool search(word)

search(word) can search a literal word or a regular expression string containing only letters a-z or .. A . means it can represent any one letter.

For example:

addWord("bad")
addWord("dad")
addWord("mad")
search("pad") -> false
search("bad") -> true
search(".ad") -> true
search("b..") -> true

这题用set做的话可能会超时,应该自己定义数据结构,构造一个单词数,这样效率更高,在搜索的时候就是dfs了, 代码如下:

 1 class WordDictionary {
 2 public:
 3     struct TreeNode{
 4     public:
 5         TreeNode *child[26];
 6         bool isWord;
 7 
 8         TreeNode() : isWord(false){
 9             for(auto & a : child)
10                 a = NULL;
11         }
12     };
13 
14     WordDictionary() {
15         root = new TreeNode();
16     }
17 
18     // Adds a word into the data structure.
19     void addWord(string word) {
20         TreeNode * p = root;
21         for(auto & a : word){
22             if(!p->child[a-a])
23                 p->child[a-a] = new TreeNode;
24             p = p->child[a-a];
25         }
26         p->isWord = true;//标记一个单词
27     }
28 
29 
30     bool searchWord(string & word, TreeNode * p, int index)
31     {
32         if(word.size() == index) return p->isWord;//这条很关键
33         if(word[index] == .){
34             for(auto & a : p->child){
35                 if(a && searchWord(word, a, index+1)) return true;
36             }
37             return false;//不要忘了
38         }else{
39             return (p->child[word[index] - a])&&searchWord(word, p->child[word[index] - a], index+1);
40         }
41     }
42 
43 
46     bool search(string word) {
47         return searchWord(word, root, 0);
48     }
49 
50 
51 
52 
53     // WordDictionary()//进入函数后会首先执行构造函数
54     // : root(new TreeNode) {}
55 private:
56     TreeNode * root;
57 };

这回写的比较乱,见谅

LeetCode OJ:Add and Search Word - Data structure design(增加以及搜索单词)

标签:

原文地址:http://www.cnblogs.com/-wang-cheng/p/4975929.html

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