设计一个支持以下两种操作的数据结构:
void addWord(word)
bool search(word)
search(word) 可以搜索文字或正则表达式字符串,字符串只包含字母 . 或 a-z 。 . 可以表示任何一个字母。
示例:
addWord("bad")
addWord("dad")
addWord("mad")
search("pad") -> false
search("bad") -> true
search(".ad") -> true
search("b..") -> true
说明:
你可以假设所有单词都是由小写字母 a-z 组成的。
理解:
可以利用Trie这种数据结构来实现,其中‘.’可以匹配任何字母,所以在查询的时候要判断字符串的每个字符是否为‘.’。
Java版本实现
package trie;
public class WordDictionary {
private class Node{
boolean isWord;
Node[] next = new Node[26];
public Node(boolean isWord) {
this.isWord = isWord;
}
public Node() {
this(false);
}
}
private Node root;
/** Initialize your data structure here. */
public WordDictionary() {
root = new Node();
}
/** Adds a word into the data structure. */
public void addWord(String word) {
Node cur = root;
for(char c : word.toCharArray()) {
if(cur.next[c - 'a'] == null)
cur.next[c - 'a'] = new Node();
cur = cur.next[c - 'a'];
}
if(!cur.isWord) {
cur.isWord = true;
}
}
/** Returns if the word is in the data structure. A word could contain the dot character '.' to represent any one letter. */
public boolean search(String word) {
return match(root , word.toCharArray() , 0);
}
private boolean match(Node node , char[] word , int index) {
if(word.length == index)
return node.isWord;
char c = word[index];
if(c != '.')
return node.next[c - 'a'] != null && match(node.next[c-'a'] , word , index + 1);
else {
for(int i = 0 ; i < node.next.length ; i ++)
if(node.next[i] != null && match(node.next[i] , word , index + 1))
return true;
return false;
}
}
}
/**
* Your WordDictionary object will be instantiated and called as such:
* WordDictionary obj = new WordDictionary();
* obj.addWord(word);
* boolean param_2 = obj.search(word);
*/