“This is the 17th day of my participation in the First Challenge 2022.
describe
Design a data structure that supports adding new words and finding if a string matches any previously added string.
Implement the WordDictionary class:
- WordDictionary() Initializes the object.
- void addWord(word) Adds word to the data structure, it can be matched later.
- bool search(word) Returns true if there is any string in the data structure that matches word or false otherwise. word may contain dots ‘.’ where dots can be matched with any letter.
Example 1:
Input ["WordDictionary","addWord","addWord","addWord","search","search","search","search"] [[],["bad"],["dad"],["mad"],["pad"],["bad"],[".ad"],["b.."]] Output [null,null,null,null,false,true,true,true] Explanation WordDictionary wordDictionary = new WordDictionary(); wordDictionary.addWord("bad"); wordDictionary.addWord("dad"); wordDictionary.addWord("mad"); wordDictionary.search("pad"); // return False wordDictionary.search("bad"); // return True wordDictionary.search(".ad"); // return True wordDictionary.search("b.." ); // return TrueCopy the code
Note:
1 <= word.length <= 500 word in addWord consists lower-case English letters. word in search consist of '.' or lower-case English letters. At most 50000 calls will be made to addWord and search.Copy the code
parsing
Design a data structure that supports adding new words and finding out if the string matches any previously added strings.
Implementing the WordDictionary class:
- WordDictionary() initializes the object
- Void addWord(word) Adds word to a data structure that can later be used for matching
- Bool search(word) Returns true if there are any strings matching word in the data structure, false otherwise. Words may contain dots ‘.’, which can be matched with any letter
This problem can be easily solved using Python’s built-in re module, re.search, by concatenating all strings into the global variable s, but note that we use a delimiter & between each word to separate the inserted word. It’s ok to use some other notation, as long as it’s not. Will do. Then we add an & to the left and right sides of word in the search function to form a pattern, so that we can use the re.search function to conduct regular search in S, as long as result has a result, it is True, otherwise it is False.
answer
class WordDictionary(object):
def __init__(self):
self.s = '&'
def addWord(self, word):
"""
:type word: str
:rtype: None
"""
self.s += word + '&'
def search(self, word):
"""
:type word: str
:rtype: bool
"""
pattern = '&' + word + '&'
result = re.search(pattern, self.s)
return True if result else False
Copy the code
The results
Runtime: Submission in Python online submissions for Design Add and Search Words Data Structure. Submissions in Python online submissions for Design Add and Search Words Data Structure.Copy the code
parsing
In fact, the above solution is still very clever, after all, using the built-in function, although it can pass, but no technical content, we still for the topic to investigate the content of the comb.
This data structure can not only insert and save all the words in word, but also support word matching function. There are two types of matching. The first type is the word that consists of all lowercase letters. You can tell if there is a match by the corresponding letter, but the other one is also mixed with. As soon as we encounter. We can only consider all letters that appear in that position, which obviously requires a Trie tree to save and search.
We simply insert each character of all words into Trie and use a Boolean variable isWord to indicate whether a word is a word or not. When we use search to find word, we simply look down the node along root, in two cases. If the word is empty and the current node isWord is True, the recursive end condition is when the word is empty and the current node isWord is True.
answer
class TrieNode():
def __init__(self):
self.children = defaultdict(TrieNode)
self.isWord = False
class WordDictionary(object):
def __init__(self):
self.root = TrieNode()
def addWord(self, word):
"""
:type word: str
:rtype: None
"""
node = self.root
for c in word:
node = node.children[c]
node.isWord = True
def search(self, word):
"""
:type word: str
:rtype: bool
"""
node = self.root
self.result = False
def dfs(node, word):
if not word:
if node.isWord:
self.result = True
return
if word[0] == ".":
for n in node.children.values():
dfs(n, word[1:])
else:
node = node.children.get(word[0])
if not node:
return
dfs(node, word[1:])
dfs(node, word)
return self.result
Copy the code
The results
Runtime: 376 MS, faster than 62.92% of Python online submissions for Design Add and Search Words Data Structure. Memory Usage: Submissions in Python online submissions for Design Add and Search Words Data Structure.Copy the code
The original link
Leetcode.com/problems/de…
Your support is my biggest motivation