久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

        當(dāng)前位置:首頁  >  技術(shù)干貨  > 為什么Redis一定要用跳表來實(shí)現(xiàn)有序集合?

        為什么Redis一定要用跳表來實(shí)現(xiàn)有序集合?

        來源:千鋒教育
        發(fā)布人:xqq
        時(shí)間: 2023-10-11 04:40:06 1696970406

        一、為什么Redis一定要用跳表來實(shí)現(xiàn)有序集合

        跳表的全稱是跳躍表,它的基礎(chǔ)是有序鏈表,在有序鏈表的基礎(chǔ)上,增加多級索引,實(shí)現(xiàn)快速查找。跳表的所有額外索引結(jié)點(diǎn)總數(shù)為 n2+n4+n8+…+4+2=n?2n2+n4+n8+…+4+2=n?2,所以跳表的空間復(fù)雜度為 O(n)O(n)。

        用跳表查找效率到底可以提升多少

        前面我講過,算法的執(zhí)行效率可以通過時(shí)間復(fù)雜度來度量,這里依舊可以用。我們知道,在一個(gè)單鏈表中查詢某個(gè)數(shù)據(jù)的時(shí)間復(fù)雜度是 O(n)。那在一個(gè)具有多級索引的跳表中,查詢某個(gè)數(shù)據(jù)的時(shí)間復(fù)雜度是多少呢?

        這里先來看一個(gè)問題,如果鏈表里有 n 個(gè)結(jié)點(diǎn),會有多少級索引呢?

        按照我們剛才講的,每兩個(gè)結(jié)點(diǎn)會抽出一個(gè)結(jié)點(diǎn)作為上一級索引的結(jié)點(diǎn),那名列前茅級索引的結(jié)點(diǎn)個(gè)數(shù)大概就是 n/2,第二級索引的結(jié)點(diǎn)個(gè)數(shù)大約就是 n/4,第三級索引的結(jié)點(diǎn)個(gè)數(shù)大約就是 n/8,依次類推,也就是說,第 k 級索引的結(jié)點(diǎn)個(gè)數(shù)是第 k-1 級索引的結(jié)點(diǎn)個(gè)數(shù)的 1/2,那第 k 級索引結(jié)點(diǎn)的個(gè)數(shù)就是 n/(2k)。

        假設(shè)索引有 h 級,較高級的索引有 2 個(gè)結(jié)點(diǎn)。通過上面的公式,我們可以得到 n/(2h)=2,從而求得 h=log2n-1。如果包含原始鏈表這一層,整個(gè)跳表的高度就是 log2n。

        我們在跳表中查詢某個(gè)數(shù)據(jù)的時(shí)候,如果每一層都要遍歷 m 個(gè)結(jié)點(diǎn),那在跳表中查詢一個(gè)數(shù)據(jù)的時(shí)間復(fù)雜度就是 O(m*logn)。那這個(gè) m 的值是多少呢?按照前面這種索引結(jié)構(gòu),我們每一級索引都非常多只需要遍歷 3 個(gè)結(jié)點(diǎn),也就是說 m=3,為什么是 3 呢?這里解釋一下:

        假設(shè)我們要查找的數(shù)據(jù)是 x,在第 k 級索引中,我們遍歷到 y 結(jié)點(diǎn)之后,發(fā)現(xiàn) x 大于 y,小于后面的結(jié)點(diǎn) z,所以我們通過 y 的 down 指針,從第 k 級索引下降到第 k-1 級索引。在第 k-1 級索引中,y 和 z 之間只有 3 個(gè)結(jié)點(diǎn)(包含 y 和 z),所以,我們在 K-1 級索引中非常多只需要遍歷 3 個(gè)結(jié)點(diǎn),依次類推,每一級索引都非常多只需要遍歷 3 個(gè)結(jié)點(diǎn)。通過上面的分析,我們得到 m=3,所以在跳表中查詢?nèi)我鈹?shù)據(jù)的時(shí)間復(fù)雜度就是 O(logn)。這個(gè)查找的時(shí)間復(fù)雜度跟二分查找是一樣的。換句話說,我們其實(shí)是基于單鏈表實(shí)現(xiàn)了二分查找,但是,有一個(gè)比較雞肋的地方就是:這種查詢效率的提升,前提是建立了很多級索引,即需要占用額外的內(nèi)存空間。

        延伸閱讀:

        二、跳表內(nèi)存使用情況

        比起單純的單鏈表,跳表需要存儲多級索引,肯定要消耗更多的存儲空間。下面來看下跳表的空間復(fù)雜度。

        假設(shè)原始鏈表大小為 n,那名列前茅級索引大約有 n/2 個(gè)結(jié)點(diǎn),第二級索引大約有 n/4 個(gè)結(jié)點(diǎn),以此類推,每上升一級就減少一半,直到剩下 2 個(gè)結(jié)點(diǎn)。如果我們把每層索引的結(jié)點(diǎn)數(shù)寫出來,就是一個(gè)等比數(shù)列。

        原始鏈表大小為n,每2個(gè)節(jié)點(diǎn)取1個(gè),則每層索引的節(jié)點(diǎn)數(shù):n/2, n/4, n/8, … , 8, 4, 2。

        這幾級索引的結(jié)點(diǎn)總和就是 n/2+n/4+n/8…+8+4+2=n-2。所以,跳表的空間復(fù)雜度是 O(n)。也就是說,如果將包含 n 個(gè)結(jié)點(diǎn)的單鏈表構(gòu)造成跳表,我們需要額外再用接近 n 個(gè)結(jié)點(diǎn)的存儲空間。那我們有沒有辦法降低索引占用的內(nèi)存空間呢?我們前面都是每兩個(gè)結(jié)點(diǎn)抽一個(gè)結(jié)點(diǎn)到上級索引,如果我們每三個(gè)結(jié)點(diǎn)或五個(gè)結(jié)點(diǎn),抽一個(gè)結(jié)點(diǎn)到上級索引,這樣是不是就不用那么多索引結(jié)點(diǎn)了呢?

        通過等比數(shù)列求和公式,總的索引結(jié)點(diǎn)大約就是 n/3+n/9+n/27+…+9+3+1=n/2。盡管空間復(fù)雜度還是 O(n),但比上面的每兩個(gè)結(jié)點(diǎn)抽一個(gè)結(jié)點(diǎn)的索引構(gòu)建方法,要減少了一半的索引結(jié)點(diǎn)存儲空間。

        實(shí)際上,在程序開發(fā)中,我們一般不必太在意索引占用的額外空間。因?yàn)楫?dāng)對象比索引結(jié)點(diǎn)大很多時(shí),那索引占用的額外空間就可以忽略了。

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        計(jì)算機(jī)網(wǎng)絡(luò)管理軟件有哪些好用?

        1、Nagios CoreNagios Core在全球范圍內(nèi)用于幫助監(jiān)控網(wǎng)絡(luò)和跟蹤各種基礎(chǔ)設(shè)施。它的主動監(jiān)控功能可以檢測它負(fù)責(zé)監(jiān)控的服務(wù)器上的網(wǎng)絡(luò)設(shè)備、服務(wù)...詳情>>

        2023-10-11 06:33:55
        oa系統(tǒng)怎么注冊?

        一、選擇合適的OA系統(tǒng)首先,需要選擇一款適合自己公司的OA系統(tǒng)。市面上有很多OA系統(tǒng),如用友、金蝶等,不同的OA系統(tǒng)有不同的功能和價(jià)格。在選擇...詳情>>

        2023-10-11 06:32:35
        大整數(shù)類型和一般的整數(shù)類型相比各有什么優(yōu)劣?

        一、大整數(shù)類型和一般的整數(shù)類型相比大整數(shù)類型和一般的整數(shù)類型相比優(yōu)點(diǎn)是不會溢出,能表示任意長度的數(shù)字做各種精度的運(yùn)算。缺點(diǎn)是沒有直接的...詳情>>

        2023-10-11 06:22:59
        功能安全開發(fā)與ASPICE和CMMI之間有什么樣的聯(lián)系?

        一、功能安全開發(fā)與ASPICE和CMMI之間的聯(lián)系CMMI是產(chǎn)品和系統(tǒng)開發(fā)的通用模型,ASPICE是針對車這個(gè)垂直領(lǐng)域,(軟件)產(chǎn)品和系統(tǒng)開發(fā)的標(biāo)準(zhǔn)。ASPI...詳情>>

        2023-10-11 05:59:32
        在C語言下數(shù)組array與鏈表linklist各自的優(yōu)點(diǎn)和缺陷是什么?

        一、在C語言下數(shù)組array與鏈表linklist各自的優(yōu)點(diǎn)和缺陷數(shù)組可以通過下標(biāo)訪問,隨機(jī)訪問效率高,鏈表需要通過指針遍歷,訪問效率低。數(shù)組在分配...詳情>>

        2023-10-11 05:43:25
        快速通道
        灯塔市| 山阳县| 堆龙德庆县| 鹤山市| 宣恩县| 东源县| 台州市| 通化县| 延吉市| 潜山县| 左云县| 株洲县| 岑巩县| 崇义县| 中超| 环江| 阿鲁科尔沁旗| 宣恩县| 通城县| 宜宾市| 秦安县| 雷州市| 巴南区| 许昌县| 开封县| 哈密市| 井陉县| 余姚市| 彭水| 平度市| 南丰县| 墨玉县| 齐齐哈尔市| 电白县| 龙泉市| 息烽县| 康平县| 日土县| 锦屏县| 女性| 承德县|