亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

字典樹的基本知識及使用C語言的相關實現

2020-01-26 14:59:42
字體:
來源:轉載
供稿:網友

概念

     如果我們有and,as,at,cn,com這些關鍵詞,那么trie樹(字典樹)是這樣的:

201587113000993.png (702×500)

     從上面的圖中,我們或多或少的可以發現一些好玩的特性。

      第一:根節點不包含字符,除根節點外的每一個子節點都包含一個字符。

      第二:從根節點到某一節點,路徑上經過的字符連接起來,就是該節點對應的字符串。

      第三:每個單詞的公共前綴作為一個字符節點保存。

 

使用范圍

     既然學Trie樹,我們肯定要知道這玩意是用來干嘛的。

     第一:詞頻統計。

            可能有人要說了,詞頻統計簡單啊,一個hash或者一個堆就可以打完收工,但問題來了,如果內存有限呢?還能這么

             玩嗎?所以這里我們就可以用trie樹來壓縮下空間,因為公共前綴都是用一個節點保存的。

     第二: 前綴匹配

            就拿上面的圖來說吧,如果我想獲取所有以"a"開頭的字符串,從圖中可以很明顯的看到是:and,as,at,如果不用trie樹,

            你該怎么做呢?很顯然樸素的做法時間復雜度為O(N2) ,那么用Trie樹就不一樣了,它可以做到h,h為你檢索單詞的長度,

            可以說這是秒殺的效果。

數據結構定義

  #define MAX 26 // 字符集大小      typedef struct trieNode {     struct trieNode *next[MAX];     int count; // 記錄該字符出現次數   } trieNode; 


next數組表示每層有多少類的數,如果只是小寫字母,26即可


實現方法
搜索字典項目的方法:

  •     從根節點開始一次搜索
  •     獲取要查找關鍵詞的第一個字母,并根據該字母選擇對應的子樹并轉到該子樹繼續進行檢索
  •     在相應的子樹上,獲取要查找關鍵詞的第二個字母,并進一步選擇對應的子樹進行檢索
  •     迭代過程
  •     在某個節點處,關鍵詞的所有字母已被取出,則讀取附在該結點上的信息,即完成查找


其他操作類似


實現模板

初始化根結點

  /**    * 初始化Trie樹根結點    */   void initTrie(trieNode **root)   {     int i;        *root = (trieNode *)malloc(sizeof(trieNode));     (*root)->count = 0;        for (i = 0; i < MAX; i ++) {       (*root)->next[i] = NULL;     }   } 

插入單詞到trie樹

 

  /**    * Trie樹插入操作    */   void insert(char *str, trieNode *root)   {     int i;        trieNode *p = root;        while (*str != '/0') {       if (p->next[*str - 'a'] == NULL) {         trieNode *tmp = (trieNode *)malloc(sizeof(trieNode));         for (i = 0; i < MAX; i ++) {           tmp->next[i] = NULL;         }         tmp->count = 1;         p->next[*str - 'a'] = tmp;         p = p->next[*str - 'a'];       } else {         p = p->next[*str - 'a'];         p->count ++;       }          str ++;     }   } 

統計查找單詞數量

  /**    * 統計前綴出現次數    */   int count(char *search, trieNode *root)   {     trieNode *p = root;        while (*search != '/0') {       if (p->next[*search - 'a'] == NULL) {         return 0;       } else {         p = p->next[*search - 'a'];         search ++;       }     }        return p->count;   } 


清理trie樹

  /**    * 清理trie樹    */   void delTrie(trieNode *root)   {     int i;        for (i = 0; i < MAX; i ++) {       if (root->next[i] != NULL) {         delTrie(root->next[i]);       }     }        free(root);   } 

時間復雜度
插入、查找的時間復雜度均為O(n),n為字符串的長度

空間復雜度較高,O(26^n),典型空間換時間


參考題目

ac代碼:

 

  #include <stdio.h>   #include <stdlib.h>   #include <string.h>      #define MAX 26 // 字符集大小      typedef struct trieNode {     struct trieNode *next[MAX];     int count; // 記錄該字符出現次數   } trieNode;         /**    * 初始化Trie樹根結點    */   void initTrie(trieNode **root)   {     int i;        *root = (trieNode *)malloc(sizeof(trieNode));     (*root)->count = 0;        for (i = 0; i < MAX; i ++) {       (*root)->next[i] = NULL;     }   }      /**    * Trie樹插入操作    */   void insert(char *str, trieNode *root)   {     int i;        trieNode *p = root;        while (*str != '/0') {       if (p->next[*str - 'a'] == NULL) {         trieNode *tmp = (trieNode *)malloc(sizeof(trieNode));         for (i = 0; i < MAX; i ++) {           tmp->next[i] = NULL;         }         tmp->count = 1;         p->next[*str - 'a'] = tmp;         p = p->next[*str - 'a'];       } else {         p = p->next[*str - 'a'];         p->count ++;       }          str ++;     }   }      /**    * 統計前綴出現次數    */   int count(char *search, trieNode *root)   {     trieNode *p = root;        while (*search != '/0') {       if (p->next[*search - 'a'] == NULL) {         return 0;       } else {         p = p->next[*search - 'a'];         search ++;       }     }        return p->count;   }      /**    * 清理trie樹    */   void delTrie(trieNode *root)   {     int i;        for (i = 0; i < MAX; i ++) {       if (root->next[i] != NULL) {         delTrie(root->next[i]);       }     }        free(root);   }         int main(void)   {     char str[15];     trieNode *root;        // 初始化根結點     initTrie(&root);        while (gets(str) && str[0] != '/0') {       // 插入Trie樹       insert(str, root);     }        // 查找前綴出現次數     while (gets(str) && str[0] != '/0') {       printf("%d/n", count(str, root));     }        delTrie(root);        return 0;   } 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩黄在线观看| 欧美成人免费在线视频| 欧美激情乱人伦一区| 久久久亚洲影院你懂的| 日韩在线视频免费观看高清中文| 午夜精品一区二区三区av| 欧美日韩国产一区二区| 日本aⅴ大伊香蕉精品视频| 成人春色激情网| 精品亚洲永久免费精品| 午夜精品美女自拍福到在线| 久久影视电视剧凤归四时歌| 日韩欧美a级成人黄色| 成人久久久久爱| 成人欧美一区二区三区在线湿哒哒| 久久这里有精品视频| 国产福利精品在线| 日韩激情片免费| 亚洲综合成人婷婷小说| 日韩电影中文字幕一区| 九九精品在线视频| 日韩在线欧美在线| 成年人精品视频| 日韩中文字幕视频在线| 日本中文字幕久久看| 日韩精品免费一线在线观看| 国产精品一区二区三区成人| 精品国产一区二区三区久久狼5月| 欧美噜噜久久久xxx| 亚洲精品资源美女情侣酒店| 欧美日韩成人在线观看| 日韩中文av在线| 91麻豆国产语对白在线观看| 欧美日韩国产va另类| 亚洲人a成www在线影院| 国产精品视频久| 国产精品扒开腿做爽爽爽男男| 国产精品美女在线观看| 日韩专区在线观看| 国产精品99久久久久久人| 91国在线精品国内播放| 久热精品视频在线免费观看| 欧美激情第一页xxx| 国产精品丝袜一区二区三区| 久久99精品国产99久久6尤物| 亚洲二区中文字幕| 国产精品大陆在线观看| 精品久久久久久久久国产字幕| 欧美孕妇毛茸茸xxxx| 在线成人一区二区| 日韩av电影在线免费播放| 国产日韩中文在线| 欧美福利视频在线| 亚洲片国产一区一级在线观看| 青青精品视频播放| 国产97免费视| 在线播放日韩精品| 97婷婷涩涩精品一区| 久99久在线视频| 久久综合伊人77777蜜臀| 日韩精品久久久久久久玫瑰园| 91国产美女在线观看| 日韩精品小视频| 久久99亚洲热视| 国产主播喷水一区二区| 亚洲精品福利在线观看| 亚洲第一色中文字幕| 日韩在线小视频| 欧美极品xxxx| 国产在线一区二区三区| 欧美日韩亚洲一区二| 亚洲欧美中文字幕| 在线观看国产精品淫| 高潮白浆女日韩av免费看| 欧美激情精品久久久久| 日韩经典一区二区三区| 中文一区二区视频| 欧美激情区在线播放| 国产偷亚洲偷欧美偷精品| 日韩美女视频免费在线观看| 欧美黑人性生活视频| 久久91亚洲人成电影网站| 欧美另类69精品久久久久9999| 久久精品国产99国产精品澳门| 国产69精品久久久久9| 欧美亚洲激情视频| 亚洲国产精久久久久久久| 国产精品久久久av久久久| 久久精品国产欧美激情| 91免费福利视频| 欧洲美女7788成人免费视频| 久久久国产精彩视频美女艺术照福利| 一色桃子一区二区| 色综合久久久久久中文网| 九九精品视频在线| 国产成人免费91av在线| 欧美电影免费观看高清完整| 日韩在线观看电影| 亚洲午夜久久久久久久| 欧美性生交xxxxx久久久| 欧美极品美女电影一区| 成人亚洲激情网| 欧美国产日韩免费| 精品国产电影一区| 最近中文字幕mv在线一区二区三区四区| 日韩成人网免费视频| 午夜精品久久久久久久99热浪潮| 性色av香蕉一区二区| 97人洗澡人人免费公开视频碰碰碰| 狠狠爱在线视频一区| 狠狠躁夜夜躁久久躁别揉| 欧美极品少妇全裸体| 国产网站欧美日韩免费精品在线观看| 中文字幕亚洲综合久久| 欧美激情亚洲一区| 91中文精品字幕在线视频| 亚洲影院在线看| 亚洲第一综合天堂另类专| 日韩国产欧美精品一区二区三区| 欧美xxxx14xxxxx性爽| 亚洲精品永久免费| 在线观看中文字幕亚洲| 久久久久国色av免费观看性色| 亚洲一二三在线| 日韩视频在线一区| 亚洲人成77777在线观看网| 国产精品啪视频| 欧美另类交人妖| 国产a∨精品一区二区三区不卡| 久久视频国产精品免费视频在线| 日韩美女免费线视频| 亲爱的老师9免费观看全集电视剧| 久久91超碰青草是什么| 欧美刺激性大交免费视频| 欧美风情在线观看| 亚洲欧美日韩精品久久奇米色影视| 久久精品一区中文字幕| 国产精品视频男人的天堂| 日韩久久精品电影| 欧美日韩电影在线观看| 欧美在线中文字幕| 国产精品美女无圣光视频| 久久久久久这里只有精品| 这里精品视频免费| 日韩中文av在线| 青青久久av北条麻妃黑人| 国产欧美一区二区三区在线| 亚洲精品成a人在线观看| 日韩黄在线观看| 亚洲第一色在线| 久久久视频精品| 国产精品情侣自拍| 精品国产91久久久久久老师| 97激碰免费视频| 日本精品性网站在线观看| 亚洲毛茸茸少妇高潮呻吟| 亚洲色图偷窥自拍| 国产精品444| 国产激情久久久| 国产精品黄页免费高清在线观看| 亚洲成人三级在线| 久久久久久噜噜噜久久久精品| 亚洲一区二区三区久久| 国产精品久久久久久久久|