Trie樹

Trie樹,又稱字典樹,前綴樹,是一種很常用的樹結(jié)構(gòu),它被廣泛用于各個(gè)方面,比如字符串檢索、中文分詞、求字符串最長(zhǎng)公共前綴和字典排序等等。

字典樹設(shè)計(jì)的核心思想是空間換時(shí)間,所以數(shù)據(jù)結(jié)構(gòu)本身比較消耗空間。但它利用了字符串的共同前綴(Common Prefix)作為存儲(chǔ)依據(jù),以此來(lái)節(jié)省存儲(chǔ)空間,并加速搜索時(shí)間。Trie 的字符串搜索時(shí)間復(fù)雜度為 O(m),m 為最長(zhǎng)的字符串的長(zhǎng)度,其查詢性能與集合中的字符串的數(shù)量無(wú)關(guān)。其在搜索字符串時(shí)表現(xiàn)出的高效,使得特別適用于構(gòu)建文本搜索和詞頻統(tǒng)計(jì)等應(yīng)用

字典樹的性質(zhì)

根節(jié)點(diǎn)(Root)不包含字符,除根節(jié)點(diǎn)外的每一個(gè)節(jié)點(diǎn)都僅包含一個(gè)字符;

從根節(jié)點(diǎn)到某一節(jié)點(diǎn)路徑上所經(jīng)過(guò)的字符連接起來(lái),即為該節(jié)點(diǎn)對(duì)應(yīng)的字符串;

任意節(jié)點(diǎn)的所有子節(jié)點(diǎn)所包含的字符都不相同;

下圖就是一個(gè)字典樹的構(gòu)造


image.png

使用golang 定義trie 樹節(jié)點(diǎn),定義一個(gè)支持漢字的Trie樹

type runeTireNode struct {
    child map[rune]*runeTireNode
    Vaule interface{}
}
type RuneTire struct {
    root *runeTireNode
}

func NewRuneTire() *RuneTire  {
    return &RuneTire{root:&runeTireNode{child:make(map[rune]*runeTireNode)}}
}
func (r *RuneTire) Insert(key string,value interface{})  {
    node := r.root
    for _,c := range key{
        if n,ok :=node.child[c];!ok{
            newNode := &runeTireNode{child:make(map[rune]*runeTireNode)}
            node.child[c] = newNode
            node = newNode
        }else{
            node = n
        }
    }
    node.Vaule = value
}

func (r *RuneTire) Get(key string) interface{}  {
    node := r.root
    for _,c := range key{
        if n,ok := node.child[c];!ok{
            return nil
        }else{
            node = n
        }
    }
    return node.Vaule
}
func main() {
    r := NewRuneTire()
    r.Insert("河北","河北")
    r.Insert("湖南","湖南")
    r.Insert("湖北","湖北省")
    fmt.Println(r.Get("湖北"))
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 字典樹(Trie)筆記 特別聲明 本文只是一篇筆記類的文章,所以不存在什么抄襲之類的。 以下為我研究時(shí)參考過(guò)的鏈接...
    Harlan1994閱讀 20,385評(píng)論 2 21
  • 1、 概述 Trie樹,又稱字典樹,單詞查找樹或者前綴樹,是一種用于快速檢索的多叉樹結(jié)構(gòu),如英文字母的字典樹是一個(gè)...
    Shadowsocks2閱讀 806評(píng)論 1 2
  • 本文內(nèi)容主要來(lái)源:http://www.cnblogs.com/konrad/p/7746030.html ...
    藍(lán)天白云bubble閱讀 957評(píng)論 0 0
  • 收到產(chǎn)品,先檢查。里面有一根加熱腰帶,一個(gè)小包(開(kāi)穴包),一個(gè)大包(瘦瘦包包),還有一個(gè)體重記錄表,一份說(shuō)明書。 ...
    窗外芭蕉_43fd閱讀 11,655評(píng)論 0 0
  • 傷心何止一次,是一次又一次,何必在意?萬(wàn)事隨他去,做好自己。柳暗花明前有路。
    山林c閱讀 734評(píng)論 7 14

友情鏈接更多精彩內(nèi)容