• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 297,  comments - 15,  trackbacks - 0
            Trie,又稱字典樹、單詞查找樹,是一種樹形結構,用于保存大量的字符串。它的優點是:利用字符串的公共前綴來節約存儲空間。
            相對來說,Trie樹是一種比較簡單的數據結構.理解起來比較簡單,正所謂簡單的東西也得付出代價.故Trie樹也有它的缺點,Trie樹的內存消耗非常大.當然,或許用左兒子右兄弟的方法建樹的話,可能會好點.

            其基本性質可以歸納為:
            1. 根節點不包含字符,除根節點外每一個節點都只包含一個字符。
            2. 從根節點到某一節點,路徑上經過的字符連接起來,為該節點對應的字符串。
            3. 每個節點的所有子節點包含的字符都不相同。

            其基本操作有:查找 插入和刪除,當然刪除操作比較少見.我在這里只是實現了對整個樹的刪除操作,至于單個word的刪除操作也很簡單.

            搜索字典項目的方法為:

            (1) 從根結點開始一次搜索;

            (2) 取得要查找關鍵詞的第一個字母,并根據該字母選擇對應的子樹并轉到該子樹繼續進行檢索;

            (3) 在相應的子樹上,取得要查找關鍵詞的第二個字母,并進一步選擇對應的子樹進行檢索。
            (4) 迭代過程……
            (5) 在某個結點處,關鍵詞的所有字母已被取出,則讀取附在該結點上的信息,即完成查找。
            其他操作類似處理.

             

            /*
            Name: Trie樹的基本實現 
            Author: MaiK 
            Description: Trie樹的基本實現 ,包括查找 插入和刪除操作
            */

            #include
            <algorithm>
            #include
            <iostream>
            using namespace std;

            const int sonnum=26,base='a';
            struct Trie
            {
                
            int num;//to remember how many word can reach here,that is to say,prefix
                bool terminal;//If terminal==true ,the current point has no following point
                struct Trie *son[sonnum];//the following point
            }
            ;
            Trie 
            *NewTrie()// create a new node
            {
                Trie 
            *temp=new Trie;
                temp
            ->num=1;temp->terminal=false;
                
            for(int i=0;i<sonnum;++i)temp->son[i]=NULL;
                
            return temp;
            }

            void Insert(Trie *pnt,char *s,int len)// insert a new word to Trie tree
            {
                Trie 
            *temp=pnt;
                
            for(int i=0;i<len;++i)
                
            {
                    
            if(temp->son[s[i]-base]==NULL)temp->son[s[i]-base]=NewTrie();
                    
            else temp->son[s[i]-base]->num++;
                    temp
            =temp->son[s[i]-base];
                }

                temp
            ->terminal=true;
            }

            void Delete(Trie *pnt)// delete the whole tree
            {
                
            if(pnt!=NULL)
                
            {
                    
            for(int i=0;i<sonnum;++i)if(pnt->son[i]!=NULL)Delete(pnt->son[i]);
                    delete pnt; 
                    pnt
            =NULL;
                }

            }

            Trie
            * Find(Trie *pnt,char *s,int len)//trie to find the current word
            {
                Trie 
            *temp=pnt;
                
            for(int i=0;i<len;++i)
                    
            if(temp->son[s[i]-base]!=NULL)temp=temp->son[s[i]-base];
                    
            else return NULL;
                
            return temp;
            }
             


            轉自:http://hi.baidu.com/luyade1987/blog/item/2667811631106657f2de320a.html
            posted on 2010-01-28 17:07 chatler 閱讀(563) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm
            <2010年9月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

            留言簿(10)

            隨筆分類(307)

            隨筆檔案(297)

            algorithm

            Books_Free_Online

            C++

            database

            Linux

            Linux shell

            linux socket

            misce

            • cloudward
            • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

            network

            OSS

            • Google Android
            • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
            • os161 file list

            overall

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲AV无码久久精品成人| 日本高清无卡码一区二区久久| 亚洲精品午夜国产VA久久成人| 色青青草原桃花久久综合| 久久久无码精品亚洲日韩京东传媒| 亚洲熟妇无码另类久久久| 88久久精品无码一区二区毛片| 日韩电影久久久被窝网| 色婷婷久久综合中文久久蜜桃av| 久久成人国产精品二三区| 欧美色综合久久久久久| 国产亚洲精品自在久久| 久久午夜免费视频| 国产精品热久久毛片| 久久久久久久久无码精品亚洲日韩 | 亚州日韩精品专区久久久| 人妻丰满AV无码久久不卡| 久久婷婷人人澡人人| 国产精品久久久久无码av| 久久国语露脸国产精品电影| 久久精品成人欧美大片| 久久精品国产亚洲一区二区| 亚洲精品乱码久久久久66| 欧美伊人久久大香线蕉综合| 精品无码久久久久久国产| 国产一区二区三区久久精品| 久久亚洲AV成人出白浆无码国产| 亚洲日本久久久午夜精品| 亚洲日本va午夜中文字幕久久 | 欧美国产成人久久精品| 久久综合丝袜日本网| 97久久久久人妻精品专区| 少妇内射兰兰久久| 97精品依人久久久大香线蕉97| 久久伊人五月天论坛| 日韩va亚洲va欧美va久久| 欧美性猛交xxxx免费看久久久| 亚洲精品97久久中文字幕无码| 亚洲欧美国产日韩综合久久| 久久人人爽人人精品视频| 色播久久人人爽人人爽人人片AV |