mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 06:48:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			42 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>Design a data structure that supports adding new words and finding if a string matches any previously added string.</p>
 | |
| 
 | |
| <p>Implement the <code>WordDictionary</code> class:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>WordDictionary()</code> Initializes the object.</li>
 | |
| 	<li><code>void addWord(word)</code> Adds <code>word</code> to the data structure, it can be matched later.</li>
 | |
| 	<li><code>bool search(word)</code> Returns <code>true</code> if there is any string in the data structure that matches <code>word</code> or <code>false</code> otherwise. <code>word</code> may contain dots <code>'.'</code> where dots can be matched with any letter.</li>
 | |
| </ul>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Example:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input</strong>
 | |
| ["WordDictionary","addWord","addWord","addWord","search","search","search","search"]
 | |
| [[],["bad"],["dad"],["mad"],["pad"],["bad"],[".ad"],["b.."]]
 | |
| <strong>Output</strong>
 | |
| [null,null,null,null,false,true,true,true]
 | |
| 
 | |
| <strong>Explanation</strong>
 | |
| 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 True
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= word.length <= 25</code></li>
 | |
| 	<li><code>word</code> in <code>addWord</code> consists of lowercase English letters.</li>
 | |
| 	<li><code>word</code> in <code>search</code> consist of <code>'.'</code> or lowercase English letters.</li>
 | |
| 	<li>There will be at most <code>3</code> dots in <code>word</code> for <code>search</code> queries.</li>
 | |
| 	<li>At most <code>10<sup>4</sup></code> calls will be made to <code>addWord</code> and <code>search</code>.</li>
 | |
| </ul>
 |