亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Golang實(shí)現(xiàn)Trie(前綴樹)的示例

 更新時(shí)間:2023年01月03日 11:22:21   作者:terrygmx  
本文主要介紹了Golang實(shí)現(xiàn)Trie(前綴樹)的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

定義

前綴樹是N叉樹的一種特殊形式。通常來(lái)說(shuō),一個(gè)前綴樹是用來(lái)存儲(chǔ)字符串的。前綴樹的每一個(gè)節(jié)點(diǎn)代表一個(gè)字符串(前綴)。每一個(gè)節(jié)點(diǎn)會(huì)有多個(gè)子節(jié)點(diǎn),通往不同子節(jié)點(diǎn)的路徑上有著不同的字符。子節(jié)點(diǎn)代表的字符串是由節(jié)點(diǎn)本身的原始字符串,以及通往該子節(jié)點(diǎn)路徑上所有的字符組成的。

下面是前綴樹的一個(gè)例子:

在這里插入圖片描述

在上圖示例中,我們?cè)诠?jié)點(diǎn)中標(biāo)記的值是該節(jié)點(diǎn)對(duì)應(yīng)表示的字符串。例如,我們從根節(jié)點(diǎn)開(kāi)始,選擇第二條路徑 ‘b’,然后選擇它的第一個(gè)子節(jié)點(diǎn) ‘a’,接下來(lái)繼續(xù)選擇子節(jié)點(diǎn) ‘d’,我們最終會(huì)到達(dá)葉節(jié)點(diǎn) “bad”。節(jié)點(diǎn)的值是由從根節(jié)點(diǎn)開(kāi)始,與其經(jīng)過(guò)的路徑中的字符按順序形成的。

值得注意的是,根節(jié)點(diǎn)表示空字符串。

前綴樹的一個(gè)重要的特性是,節(jié)點(diǎn)所有的后代都與該節(jié)點(diǎn)相關(guān)的字符串有著共同的前綴。這就是前綴樹名稱的由來(lái)。

我們?cè)賮?lái)看這個(gè)例子。例如,以節(jié)點(diǎn) “b” 為根的子樹中的節(jié)點(diǎn)表示的字符串,都具有共同的前綴 “b”。反之亦然,具有公共前綴 “b” 的字符串,全部位于以 “b” 為根的子樹中,并且具有不同前綴的字符串來(lái)自不同的分支。

前綴樹有著廣泛的應(yīng)用,例如自動(dòng)補(bǔ)全,拼寫檢查等等。我們將在后面的章節(jié)中介紹實(shí)際應(yīng)用場(chǎng)景。

問(wèn)題描述

實(shí)現(xiàn)一個(gè) Trie (前綴樹),包含 insert, search, 和 startsWith 這三個(gè)操作。

示例:

Trie trie = new Trie();

trie.insert("apple");
trie.search("apple");   // 返回 true
trie.search("app");     // 返回 false
trie.startsWith("app"); // 返回 true
trie.insert("app");   
trie.search("app");     // 返回 true

說(shuō)明:

你可以假設(shè)所有的輸入都是由小寫字母 a-z 構(gòu)成的。
保證所有輸入均為非空字符串。

實(shí)現(xiàn)思路:

由于所有輸入都是小寫字母構(gòu)成,可以用桶的方式實(shí)現(xiàn),雖然有空間浪費(fèi),但是速度最快。

同時(shí)要實(shí)現(xiàn)搜索詞和搜索詞前綴??紤]加入布爾標(biāo)識(shí)是否是一個(gè)詞。但插入詞的時(shí)候,到詞的最后一個(gè)字母時(shí),將該節(jié)點(diǎn)布爾設(shè)為true 代碼:

type Trie struct {
	isWord   bool
	children [26]*Trie
}

/** Initialize your data structure here. */
func Constructor() Trie {
	return Trie{}
}

/** Inserts a word into the trie. */
func (this *Trie) Insert(word string) {
	cur := this
	for i, c := range word {
		n := c - 'a'

		if cur.children[n] == nil {
			cur.children[n] = &Trie{}

		}
		cur = cur.children[n]
		if i == len(word)-1 {
			cur.isWord = true
		}

	}
}

/** Returns if the word is in the trie. */
func (this *Trie) Search(word string) bool {
	cur := this
	for _, c := range word {
		n := c - 'a'
		if cur.children[n] == nil {
			return false
		}
		cur = cur.children[n]
	}
	return cur.isWord
}

/** Returns if there is any word in the trie that starts with the given prefix. */
func (this *Trie) StartsWith(prefix string) bool {
	cur := this
	for _, c := range prefix {
		n := c - 'a'
		if cur.children[n] == nil {
			return false
		}
		cur = cur.children[n]
	}
	return true
}

/**
 * Your Trie object will be instantiated and called as such:
 * obj := Constructor();
 * obj.Insert(word);
 * param_2 := obj.Search(word);
 * param_3 := obj.StartsWith(prefix);
 */

到此這篇關(guān)于Golang實(shí)現(xiàn)Trie(前綴樹)的示例的文章就介紹到這了,更多相關(guān)Golang 前綴樹內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Go+Redis實(shí)現(xiàn)延遲隊(duì)列實(shí)操

    Go+Redis實(shí)現(xiàn)延遲隊(duì)列實(shí)操

    這篇文章主要介紹了Go+Redis實(shí)現(xiàn)延遲隊(duì)列實(shí)操,延遲隊(duì)列是一種非常使用的數(shù)據(jù)結(jié)構(gòu),我們經(jīng)常有需要延遲推送處理消息的場(chǎng)景,比如延遲60秒發(fā)送短信,延遲30分鐘關(guān)閉訂單,消息消費(fèi)失敗延遲重試等
    2022-09-09
  • golang下的viper包的簡(jiǎn)單使用方式

    golang下的viper包的簡(jiǎn)單使用方式

    這篇文章主要介紹了golang下的viper包的簡(jiǎn)單使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • GO語(yǔ)言Context的作用及各種使用方法

    GO語(yǔ)言Context的作用及各種使用方法

    golang的Context包是專門用來(lái)處理多個(gè)goroutine之間與請(qǐng)求域的數(shù)據(jù)、取消信號(hào)、截止時(shí)間等相關(guān)操作,下面這篇文章主要給大家介紹了關(guān)于GO語(yǔ)言Context的作用及各種使用方法的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • go cron定時(shí)任務(wù)的基本使用講解

    go cron定時(shí)任務(wù)的基本使用講解

    這篇文章主要為大家介紹了gocron定時(shí)任務(wù)的基本使用講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 淺析Go語(yǔ)言如何在select語(yǔ)句中實(shí)現(xiàn)優(yōu)先級(jí)

    淺析Go語(yǔ)言如何在select語(yǔ)句中實(shí)現(xiàn)優(yōu)先級(jí)

    這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言如何在select語(yǔ)句中實(shí)現(xiàn)優(yōu)先級(jí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • Golang實(shí)現(xiàn)自定義recovery中間件

    Golang實(shí)現(xiàn)自定義recovery中間件

    在?Golang?的?Web?項(xiàng)目中,自定義?recovery?中間件是一種常見(jiàn)的做法,用于捕獲并處理應(yīng)用程序的運(yùn)行時(shí)錯(cuò)誤,下面我們就來(lái)看看具體如何實(shí)現(xiàn)吧
    2023-09-09
  • golang連接mysql數(shù)據(jù)庫(kù)操作使用示例

    golang連接mysql數(shù)據(jù)庫(kù)操作使用示例

    這篇文章主要為大家介紹了golang連接mysql數(shù)據(jù)庫(kù)操作使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • Go語(yǔ)言中使用gorm小結(jié)

    Go語(yǔ)言中使用gorm小結(jié)

    這篇文章主要給大家介紹了Go語(yǔ)言中如何使用gorm,文中介紹的很詳細(xì),有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2016-12-12
  • Go語(yǔ)言入門13之runtime包案例講解

    Go語(yǔ)言入門13之runtime包案例講解

    這篇文章主要介紹了Go語(yǔ)言入門runtime包相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • 一文帶你了解Go語(yǔ)言中的函數(shù)

    一文帶你了解Go語(yǔ)言中的函數(shù)

    函數(shù)是編程中不可或缺的組成部分,在本文中,我們將詳細(xì)介紹Go語(yǔ)言中函數(shù)的概念和使用方法,包括函數(shù)的定義、參數(shù)和返回值等,需要的可以參考一下
    2023-06-06

最新評(píng)論