91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++實現LeetCode之添加和查找單詞的示例分析

發布時間:2021-08-10 09:10:31 來源:億速云 閱讀:138 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關C++實現LeetCode之添加和查找單詞的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

[LeetCode] 211.Add and Search Word - Data structure design 添加和查找單詞-數據結構設計

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

Note:
You may assume that all words are consist of lowercase letters a-z.

click to show hint.

You should be familiar with how a Trie works. If not, please work on this problem: Implement Trie (Prefix Tree) first.

LeetCode出新題的速度越來越快了,有點跟不上節奏的感覺了。這道題如果做過之前的那道 Implement Trie (Prefix Tree) 實現字典樹(前綴樹)的話就沒有太大的難度了,還是要用到字典樹的結構,唯一不同的地方就是search的函數需要重新寫一下,因為這道題里面'.'可以代替任意字符,所以一旦有了'.',就需要查找所有的子樹,只要有一個返回true,整個search函數就返回true,典型的DFS的問題,其他部分跟上一道實現字典樹沒有太大區別,代碼如下:

class WordDictionary {
public:
    struct TrieNode {
    public:
        TrieNode *child[26];
        bool isWord;
        TrieNode() : isWord(false) {
            for (auto &a : child) a = NULL;
        }
    };
    
    WordDictionary() {
        root = new TrieNode();
    }
    
    // Adds a word into the data structure.
    void addWord(string word) {
        TrieNode *p = root;
        for (auto &a : word) {
            int i = a - 'a';
            if (!p->child[i]) p->child[i] = new TrieNode();
            p = p->child[i];
        }
        p->isWord = true;
    }

    // Returns if the word is in the data structure. A word could
    // contain the dot character '.' to represent any one letter.
    bool search(string word) {
        return searchWord(word, root, 0);
    }
    
    bool searchWord(string &word, TrieNode *p, int i) {
        if (i == word.size()) return p->isWord;
        if (word[i] == '.') {
            for (auto &a : p->child) {
                if (a && searchWord(word, a, i + 1)) return true;
            }
            return false;
        } else {
            return p->child[word[i] - 'a'] && searchWord(word, p->child[word[i] - 'a'], i + 1);
        }
    }
    
private:
    TrieNode *root;
};

// Your WordDictionary object will be instantiated and called as such:
// WordDictionary wordDictionary;
// wordDictionary.addWord("word");
// wordDictionary.search("pattern");

關于“C++實現LeetCode之添加和查找單詞的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁强县| 碌曲县| 烟台市| 垦利县| 宣汉县| 朝阳区| 宜春市| 肥东县| 宜黄县| 霸州市| 吐鲁番市| 宣威市| 海南省| 灵璧县| 化隆| 武冈市| 伊宁市| 亳州市| 湟中县| 长葛市| 洪江市| 额济纳旗| 台山市| 五家渠市| 万荣县| 于都县| 临沭县| 平昌县| 云梦县| 汉寿县| 文登市| 虞城县| 武宁县| 磴口县| 永川市| 什邡市| 惠来县| 张家港市| 苏尼特左旗| 泽州县| 纳雍县|