Implement a magic directory with buildDict
, and search
methods.ui
For the method buildDict
, you'll be given a list of non-repetitive words to build a dictionary.this
For the method search
, you'll be given a word, and judge whether if you modify exactly one character into another character in this word, the modified word is in the dictionary you just built.spa
Example 1:code
Input: buildDict(["hello", "leetcode"]), Output: Null Input: search("hello"), Output: False Input: search("hhllo"), Output: True Input: search("hell"), Output: False Input: search("leetcoded"), Output: False
Note:blog
a-z
.
Runtime: 0 ms, faster than 100.00% of C++ online submissions for Implement Magic Dictionary.ip
class MagicDictionary { public: vector<string> strvec; explicit MagicDictionary() = default; void buildDict(const vector<string>& dict) { strvec = dict; } bool search(const string& word) { for(auto& vs : strvec){ if(vs.size() != word.size()) continue; int idx = -1; bool fit = true; unordered_set<char> s; for(int i=0; i<word.size(); i++){ s.insert(word[i]); if(idx == -1 && word[i] != vs[i]) {idx = i;} else if(idx != -1 && word[i] != vs[i]) {fit = false; break;} } if(idx != -1 && fit && s.count(word[idx])) return true; } return false; } };