国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

「算法與數(shù)據(jù)結(jié)構(gòu)」Trie樹之美

開發(fā) 算法
這次分享的Trie字典樹,是數(shù)據(jù)結(jié)構(gòu)專題中的一個(gè)分支,認(rèn)識(shí)了解Trie這種樹型數(shù)據(jù)結(jié)構(gòu),對(duì)構(gòu)建算法與數(shù)據(jù)結(jié)構(gòu)知識(shí)體系有一定的幫助。

[[349418]]

 前言

這次分享的Trie字典樹,是數(shù)據(jù)結(jié)構(gòu)專題中的一個(gè)分支,認(rèn)識(shí)了解Trie這種樹型數(shù)據(jù)結(jié)構(gòu),對(duì)構(gòu)建算法與數(shù)據(jù)結(jié)構(gòu)知識(shí)體系有一定的幫助。

我對(duì)Trie樹的理解:把字符串都串接起來,消滅不必要的存儲(chǔ),利用的就是字符串的公共前綴。

其實(shí)對(duì)于它的理解,你理解了這句話即可👇

利用字符串的公共前綴來減少查詢時(shí)間,最大限度的減少無謂的字符串比較,查詢效率比哈希樹高。

如果你還不了解什么是Trie數(shù)據(jù)結(jié)構(gòu)的話,或者知道一些,但是對(duì)于它具體是如何實(shí)現(xiàn)一個(gè)簡(jiǎn)單Trie樹時(shí),那么這篇文章可能適合你閱讀。

那么圍繞以下幾個(gè)點(diǎn)來展開介紹Trie樹👇

  • 基本概念
  • 基本性質(zhì)
  • 應(yīng)用場(chǎng)景
  • 2個(gè)例題

基本概念

首先,我們對(duì)Trie樹得做一些基本的了解。Trie樹中文名叫字典樹,前綴樹等,接下來我就以字典樹稱呼。

我們來看下維基百科對(duì)它的描述吧⬇️

在計(jì)算機(jī)科學(xué)中,trie,又稱前綴樹或字典樹,是一種有序樹,用于保存關(guān)聯(lián)數(shù)組,其中的鍵通常是字符串。與二叉查找樹不同,鍵不是直接保存在節(jié)點(diǎn)中,而是由節(jié)點(diǎn)在樹中的位置決定。一個(gè)節(jié)點(diǎn)的所有子孫都有相同的前綴,也就是這個(gè)節(jié)點(diǎn)對(duì)應(yīng)的字符串,而根節(jié)點(diǎn)對(duì)應(yīng)空字符串。一般情況下,不是所有的節(jié)點(diǎn)都有對(duì)應(yīng)的值,只有葉子節(jié)點(diǎn)和部分內(nèi)部節(jié)點(diǎn)所對(duì)應(yīng)的鍵才有相關(guān)的值。

樸實(shí)無華的描述,其實(shí)我們看一張圖就能看明白了~,我在網(wǎng)上找了一張不錯(cuò)的圖,具體的出處,這里就不補(bǔ)充了,因?yàn)閷?shí)在找不到原作者~

 

字典樹圖解1

這里需要說明的內(nèi)容就是,一般而言,應(yīng)該是用一個(gè)點(diǎn)來表示一個(gè)字符,這里為了更好的說明,所以我就是用邊來描述字符。

可以發(fā)現(xiàn),這棵字典樹用邊來代表字母,而從根結(jié)點(diǎn)到樹上某一結(jié)點(diǎn)的路徑就代表了一個(gè)字符串。舉個(gè)例子, 1→2→6表示的就是字符串 aba 。

再比如,1→4→8構(gòu)成的字符串是ca,那么如果在往下拓展的話,我們是不是有 caa,cab,那么他們都會(huì)經(jīng)過1→4→8,這些路徑,說明他們是有一段公共的前綴,這個(gè)前綴的內(nèi)容就是ca,說道這里,我們就知道字典樹利用的就是字符串的前綴來解決問題。

那么具體它有哪些性質(zhì)的話,我們下文介紹一下~

基本性質(zhì)

對(duì)于上述概念有了一定的理解后,我們接下來就看下Trie樹的基本性質(zhì)。

可以根據(jù)這個(gè),大體上分成三個(gè)點(diǎn)來說👇

  1. 根節(jié)點(diǎn)不包含字符,除根節(jié)點(diǎn)外,每個(gè)節(jié)點(diǎn)只包含一個(gè)字符。
  2. 從根節(jié)點(diǎn)到某一個(gè)節(jié)點(diǎn),路徑上經(jīng)過的字符連接起來,為該節(jié)點(diǎn)對(duì)應(yīng)的字符串。
  3. 每個(gè)節(jié)點(diǎn)的所有子節(jié)點(diǎn)包含的字符串不相同。

接下來我們可以稍微分析一下,可以結(jié)合一個(gè)圖來看看👇

我們通過拿how,hi,her,hello,so,see這6個(gè)字符串構(gòu)造出來的就是下面圖這個(gè)樣子。

 

 


圖解Trie樹

 

第一個(gè)性質(zhì):

從圖中也可以看出,根節(jié)點(diǎn)是/, 代表的內(nèi)容也就是空,其他的節(jié)點(diǎn)比如,根節(jié)點(diǎn)下一個(gè)層級(jí),有 h和s,分別代表的是兩個(gè)字符。

第二個(gè)性質(zhì):

從根節(jié)點(diǎn)到某一個(gè)節(jié)點(diǎn),路徑上經(jīng)過的字符連接起來,為該節(jié)點(diǎn)對(duì)應(yīng)的字符串。

比如how表示的就是一個(gè)字符串,hi,也表示的是一個(gè)字符串,可是你會(huì)不會(huì)好奇,he和hel為什么不能表示一個(gè)字符串呢?

當(dāng)你想到這里的話,說明你已經(jīng)看得很仔細(xì),馬上就要掌握它了,確實(shí),從圖中看,我們會(huì)發(fā)現(xiàn)有些節(jié)點(diǎn)顏色不同,這是因?yàn)椋覀冾A(yù)定好以這個(gè)深色的節(jié)點(diǎn)代表當(dāng)前是一個(gè)字符串的結(jié)尾,想一想,這樣子的作用是啥?

那么實(shí)際代碼中,我們應(yīng)該如何去約定或者做個(gè)標(biāo)記呢,其實(shí)只要設(shè)置一個(gè)標(biāo)記位即可。

比如下面這樣子👇

  1. const TrieNode = function () { 
  2.   this.next = Object.create(null
  3.   this.isEnd = false 
  4. }; 

當(dāng)前的isEnd變量就表示當(dāng)前的節(jié)點(diǎn)是不是結(jié)束串,當(dāng)isEnd為True時(shí),表示從根節(jié)點(diǎn)開始,到這個(gè)字符,所構(gòu)成的字符串是存在的,是一個(gè)完整的字符串。

第三個(gè)性質(zhì):

每個(gè)節(jié)點(diǎn)的所有子節(jié)點(diǎn)包含的字符串不相同。

很明顯,我們從根節(jié)點(diǎn)開始,依次往下走,會(huì)發(fā)現(xiàn),每個(gè)節(jié)點(diǎn)下面的節(jié)點(diǎn)是不相同的,所以依次組成的字符串不可能相同。

應(yīng)用場(chǎng)景

對(duì)Trie樹,有一定了解后,我們就可以看看它有哪些的實(shí)際應(yīng)用場(chǎng)景了。

這里參考的是網(wǎng)上所提供的幾個(gè)點(diǎn)👇

在搜索引擎中關(guān)鍵詞提示,引擎會(huì)自動(dòng)彈出匹配關(guān)鍵詞的下拉框,這種應(yīng)用場(chǎng)景大家應(yīng)該都很熟悉。

 

 

下拉框

 

 

那么應(yīng)該如何利用一種高效的數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)呢,這里就符合字典樹的性質(zhì),所以可以利用字典樹來構(gòu)造特定的數(shù)據(jù),達(dá)到一種更加快速檢索的效果。

字符串檢索

事先將已知的一些字符串(字典)的有關(guān)信息保存到trie樹里,查找另外一些未知字符串是否出現(xiàn)過或者出現(xiàn)頻率,可以舉例子說明情況👇

  • 1000萬字符串,其中有些是重復(fù)的,需要把重復(fù)的全部去掉,保留沒有重復(fù)的字符串。
  • 給出N 個(gè)單詞組成的熟詞表,以及一篇全用小寫英文書寫的文章,請(qǐng)你按最早出現(xiàn)的順序?qū)懗鏊胁辉谑煸~表中的生詞。

詞頻統(tǒng)計(jì)

給定很長(zhǎng)的一個(gè)串,統(tǒng)計(jì)頻數(shù)出現(xiàn)次數(shù)最多情況,舉個(gè)例子👇

  • 有一個(gè)1G大小的一個(gè)文件,里面每一行是一個(gè)詞,詞的大小不超過16字節(jié),內(nèi)存限制大小是1M。返回頻數(shù)最高的100個(gè)詞。
  • 一個(gè)文本文件,大約有一萬行,每行一個(gè)詞,要求統(tǒng)計(jì)出其中最頻繁出現(xiàn)的前10個(gè)詞,請(qǐng)給出思想,給出時(shí)間復(fù)雜度分析。

字符串最長(zhǎng)公共前綴

到現(xiàn)在,我們應(yīng)該知道,Trie樹利用多個(gè)字符串的公共前綴來節(jié)省存儲(chǔ)空間,當(dāng)我們把大量字符串存儲(chǔ)到一棵trie樹上時(shí),我們可以快速得到某些字符串的公共前綴,所以可以利用這個(gè)特點(diǎn)來解決一些前綴問題。

非要舉個(gè)例子的話,有個(gè)例子👇

  • 給出N 個(gè)小寫英文字母串,以及Q 個(gè)詢問,即詢問某兩個(gè)串的最長(zhǎng)公共前綴的長(zhǎng)度是多少?

應(yīng)用場(chǎng)景還是有很多的,剩下的可以自行去探索,接下來,我們通過實(shí)際的題目來看看,如何構(gòu)造字典樹吧~

2個(gè)例子

接下來,我們通過二個(gè)題目作為例子,來看看字典樹在實(shí)際應(yīng)用可以解決哪些問題👇

詞典中最長(zhǎng)的單詞⭐

鏈接:詞典中最長(zhǎng)的單詞

給出一個(gè)字符串?dāng)?shù)組words組成的一本英語詞典。從中找出最長(zhǎng)的一個(gè)單詞,該單詞是由words詞典中其他單詞逐步添加一個(gè)字母組成。若其中有多個(gè)可行的答案,則返回答案中字典序最小的單詞。

若無答案,則返回空字符串。

示例 1:

  1. 輸入: 
  2. words = ["w","wo","wor","worl""world"
  3. 輸出:"world" 
  4. 解釋:  
  5. 單詞"world"可由"w""wo""wor", 和 "worl"添加一個(gè)字母組成。 

示例 2:

  1. 輸入: 
  2. words = ["a""banana""app""appl""ap""apply""apple"
  3. 輸出:"apple" 
  4. 解釋: 
  5. "apply""apple"都能由詞典中的單詞組成。但是"apple"的字典序小于"apply"。 

提示:

這題無非就是找到一個(gè)最長(zhǎng)的單詞,可以拆分成words數(shù)組中某一部分,最暴力的思路就是去枚舉每一項(xiàng),但是這樣子的時(shí)間復(fù)雜度是巨大的, 這個(gè)時(shí)候,我們是不是可以思考一下,這個(gè)問題有哪些地方是共性的呢?

  • 沒錯(cuò),就是前綴是相同的,從這點(diǎn)來看,是不是就可以利用這個(gè)前綴樹,把它數(shù)據(jù)存儲(chǔ)下來
  • 然后遍歷一遍字典樹,只要這顆樹只有一個(gè)分支,則表示它有解,如果存在兩個(gè)分支以上的話,則無答案。

復(fù)雜度分析

這點(diǎn)應(yīng)該很好理解,這里就跳過了。

這里的話,我的解法構(gòu)造字典樹,當(dāng)然了,也有其他的解法,這里就不展開了,可以看下我的代碼噢~

 

 

最長(zhǎng)的串

 

 

代碼點(diǎn)這里☑️

其實(shí)你會(huì)發(fā)現(xiàn),構(gòu)造一個(gè)Trie樹的話,是很消耗空間的,有點(diǎn)空間換時(shí)間的意思,所以具體得根據(jù)實(shí)際的題目來解決問題。

實(shí)現(xiàn)Trie(前綴樹)⭐⭐

鏈接:實(shí)現(xiàn) Trie (前綴樹)

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

示例:

  1. Trie trie = new Trie(); 
  2. trie.insert("apple"); 
  3. trie.search("apple");   // 返回 true 
  4. trie.search("app");     // 返回 false 
  5. trie.startsWith("app"); // 返回 true 
  6. trie.insert("app");    
  7. trie.search("app");     // 返回 true 

說明:

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

這個(gè)題目就是典型的寫Trie樹,對(duì)于第一次寫這個(gè)題目的話,如果沒有思路的話,可以嘗試先看看別人的代碼,看看基本的套路在哪里。

話不多說,可以參考這份代碼,可以看看如何構(gòu)造一顆字典樹👇

 

 

leetcode-實(shí)現(xiàn)Trie樹

 

 

代碼點(diǎn)這里☑️

剩下的刪除操作,還有統(tǒng)計(jì)字符串出現(xiàn)的頻率,可以自己來實(shí)現(xiàn)一下,這個(gè)基本上不難,畫個(gè)圖,就知道如何實(shí)現(xiàn)啦~

題目是做不完的,做完這些題目后,希望你能對(duì)Trie字典樹有所認(rèn)識(shí),能對(duì)它有更加深入的理解~,接下來準(zhǔn)備了四道題集,希望對(duì)你們有幫助~

詞典中最長(zhǎng)的單詞

實(shí)現(xiàn) Trie (前綴樹)

單詞搜索 II

Loading question

 

責(zé)任編輯:姜華 來源: 前端UpUp
相關(guān)推薦

2020-11-02 09:15:47

算法與數(shù)據(jù)結(jié)構(gòu)

2020-10-12 11:48:31

算法與數(shù)據(jù)結(jié)構(gòu)

2020-10-20 08:14:08

算法與數(shù)據(jù)結(jié)構(gòu)

2022-09-26 07:56:53

AVL算法二叉樹

2022-09-21 07:57:33

二叉搜索樹排序二叉樹

2021-03-18 08:44:20

Java數(shù)據(jù)結(jié)構(gòu)算法

2017-10-10 16:59:28

Java數(shù)據(jù)結(jié)構(gòu)算法解析

2020-12-31 05:31:01

數(shù)據(jù)結(jié)構(gòu)算法

2020-10-21 14:57:04

數(shù)據(jù)結(jié)構(gòu)算法圖形

2023-03-08 08:03:09

數(shù)據(jù)結(jié)構(gòu)算法歸并排序

2022-01-18 19:13:52

背包問題數(shù)據(jù)結(jié)構(gòu)算法

2023-10-27 07:04:20

2021-04-07 09:26:37

Java數(shù)據(jù)結(jié)構(gòu)算法

2023-03-31 08:24:29

數(shù)據(jù)結(jié)構(gòu)算法數(shù)目

2009-08-11 14:51:11

C#數(shù)據(jù)結(jié)構(gòu)與算法

2021-07-16 04:57:45

Go算法結(jié)構(gòu)

2021-12-10 11:27:59

數(shù)據(jù)結(jié)構(gòu)算法單調(diào)遞增的數(shù)字

2009-08-11 14:43:42

C#數(shù)據(jù)結(jié)構(gòu)與算法

2021-12-08 11:31:43

數(shù)據(jù)結(jié)構(gòu)算法合并區(qū)間

2021-12-21 11:39:01

數(shù)據(jù)結(jié)構(gòu)算法同構(gòu)字符串
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产精品久久久久久av| 国产又爽又黄的激情精品视频| 人成在线免费视频| 国内精品久久久久影院薰衣草 | 欧美精品在线观看播放| 国产视频三区| 91在线国内视频| www.好吊操| 国产丶欧美丶日本不卡视频| 亚洲一区不卡在线| 麻豆一区二区在线| 亚洲三区视频| 久久99国产精品久久99| 一区二区冒白浆视频| 久久99精品国产.久久久久久| 日韩av一区二区三区在线| 久久精品一区二区国产| 国产在线精品日韩| 亚洲欧洲综合| 久久久久久久久四区三区| 99成人免费视频| 日韩高清三级| 日本午夜精品一区二区三区电影| 亚洲日本电影在线| 日韩av电影在线免费播放| 在线一区亚洲| heyzo高清国产精品| 久久综合成人精品亚洲另类欧美 | 国产精品美女视频| wwww.国产| 国产欧美日韩在线看| 免费高清成人| 亚洲电影一区二区| 人成在线免费视频| 日韩女优制服丝袜电影| 亚洲永久av| 免费av一区二区| 自拍偷拍一区| 国产精品国产精品国产专区不卡| 久久久久久黄| 乱熟女高潮一区二区在线| 久久日韩精品一区二区五区| 国内外成人免费在线视频| 亚洲综合一二三区| 蜜桃视频网站在线观看| 亚洲第一天堂无码专区| 日韩三级成人| 国产精品视频中文字幕91| 欧美日韩国产高清| 自拍偷拍99| 国产精品无人区| 日本免费不卡| 日韩av在线一区| 91蝌蚪精品视频| 亚洲一区二区三| 国产美女av一区二区三区| 日韩欧美国产片| 欧美手机在线视频| 日韩伦理三区| 国产成人激情小视频| 在线日韩视频| 无码人妻精品一区二区三区在线| 一区二区三区四区高清精品免费观看 | 久久精彩视频| 成人美女在线观看| 中文字幕免费在线| 日韩电影大全免费观看2023年上| jizz久久精品永久免费| 成人免费视频网站入口| 成人午夜精品一区二区三区| 97国产在线| 亚洲男女性事视频| 欧洲杯半决赛直播| 正在播放久久| 亚洲精品老司机| 国产高清自产拍av在线| 欧美亚洲激情在线| 免播放器亚洲| www浪潮av99com| 日韩一区二区在线看片| 99a精品视频在线观看| 精品日韩美女| 亚洲天堂网中文字| 成人免费影院| 国产区欧美区日韩区| 国产婷婷色一区二区三区在线| 大胆av不用播放器在线播放| 久久久精品影院| 美女精品在线| 三级黄色网址| 乱亲女秽乱长久久久| 久久久综合网| 濑亚美莉一二区在线视频| 亚洲少妇激情视频| 亚洲国产1区| 免费黄色网页| 在线视频日韩精品| 国产精品嫩草99av在线| 免费看的国产视频网站| 少妇高潮久久77777| 99在线精品免费视频九九视| 77777在线| 精品国产欧美成人夜夜嗨| 国产欧美一区二区三区国产幕精品| 少妇网站在线观看| 国产亚洲视频在线| 三级在线观看一区二区| 三级国产在线观看| 欧美中文字幕第一页| 成人av在线资源网站| 少妇av在线| 国产欧美日韩综合精品二区| 亚洲一区成人在线| 日本精品一区二区三区在线观看视频| 精品在线观看一区二区| 亚洲一区二区在线免费观看视频 | 亚洲AV无码成人精品一区| 色综合久久综合| 欧美久久综合网| 四虎最新网站| 欧美日本中文字幕| 99久久婷婷国产精品综合| 国产蜜臀在线| 秋霞在线观看一区二区三区| 国产最新精品| 色婷婷综合缴情免费观看| 一二美女精品欧洲| 99riav1国产精品视频| 91小视频网站| 亚洲国产婷婷香蕉久久久久久| 日韩中文在线电影| 黄色国产网站| 亚洲欧美国内爽妇网| 成人亚洲免费| 欧美黑人经典片免费观看| 日韩av中文在线| 成人三级av在线| 在线视频不卡国产| 欧美网站大全在线观看| 青青一区二区| 国产又黄又猛视频| 91国在线高清视频| 久久精品一区二区三区不卡牛牛| 波多野结衣视频一区二区| 欧美亚洲爱爱另类综合| 91精品国产综合久久久久| 亚洲日本国产| 成人影院在线看| 欧美激情国产日韩| 亚洲精品在线观看视频| 国产一区不卡视频| 中文字幕综合| 4虎在线播放1区| 国产精品日日做人人爱| 色天使色偷偷av一区二区| 99国产精品私拍| 999av小视频在线| 久久久久久久久久久视频| 欧美亚洲成人免费| 在线视频一区二区免费| 秋霞成人午夜伦在线观看| 日本一区免费网站| 亚州福利视频| 99视频免费观看蜜桃视频| 91精品国产综合久久精品图片| 久久精品国产亚洲一区二区三区| 秋霞国产精品| 369你懂的电影天堂| 国产精品美女黄网| 精品视频在线播放免| 中文字幕+乱码+中文字幕一区| 欧美精品色图| а√中文在线8| 91专区在线观看| 国产成人a亚洲精品| 91.com视频| av电影天堂一区二区在线观看| 国产亚洲一卡2卡3卡4卡新区| 欧美精品日韩少妇| 91精品91久久久中77777老牛| 欧美影院久久久| 日韩一区二区在线观看视频播放| 免费电影网站在线视频观看福利| 欧美一级欧美一级| 久久综合精品一区| 性色av一区二区三区免费| 欧美三级蜜桃2在线观看| 综合久久给合久久狠狠狠97色 | 国产一区视频在线播放| 日本精品福利视频| 精品国产伦一区二区三区免费| 成人午夜视频福利| 成人在线亚洲| 色老头在线观看| 国产国语**毛片高清视频| 日本一区二区在线视频观看| 欧美激情第三页| 精品福利一二区| 欧美日韩免费一区| 国产性色一区二区|