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

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

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

千鋒教育

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

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

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

當(dāng)前位置:首頁  >  技術(shù)干貨  > 為什么STL和linux都使用紅黑樹作為平衡樹的實?

為什么STL和linux都使用紅黑樹作為平衡樹的實?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-11 02:49:15 1696963755

一、為什么STL和linux都使用紅黑樹作為平衡樹的實現(xiàn)

選擇紅黑樹作為底層實現(xiàn)紅黑樹是一種類平衡樹, 但它不是高度的平衡樹, 但平衡的效果已經(jīng)很好了。STL map , nginx,linux 虛擬內(nèi)存管理,他們都有紅黑樹的應(yīng)用。

1. 如果插入一個node引起了樹的不平衡,AVL和RB-Tree都是非常多只需要2次旋轉(zhuǎn)操作,即兩者都是O(1);但是在刪除node引起樹的不平衡時,最壞情況下,AVL需要維護從被刪node到root這條路徑上所有node的平衡性,因此需要旋轉(zhuǎn)的量級O(logN),而RB-Tree非常多只需3次旋轉(zhuǎn),只需要O(1)的復(fù)雜度。

2. 其次,AVL的結(jié)構(gòu)相較RB-Tree來說更為平衡,在插入和刪除node更容易引起Tree的unbalance,因此在大量數(shù)據(jù)需要插入或者刪除時,AVL需要rebalance的頻率會更高。因此,RB-Tree在需要大量插入和刪除node的場景下,效率更高。自然,由于AVL高度平衡,因此AVL的search效率更高。

3. map的實現(xiàn)只是折衷了兩者在search、insert以及delete下的效率??傮w來說,RB-tree的統(tǒng)計性能是高于AVL的。

延伸閱讀

二、AVL樹(平衡二叉樹)

AVL樹是帶有平衡條件的二叉查找樹,一般是用平衡因子差值判斷是否平衡并通過旋轉(zhuǎn)來實現(xiàn)平衡,左右子樹的高度差不超過1,和紅黑樹相比,AVL樹是嚴(yán)格的平衡二叉樹,平衡條件必須滿足(所有節(jié)點的左右子樹高度差的絕對值不超過1。不管我們是執(zhí)行插入還是刪除操作,只要不滿足上面的條件,就要通過旋轉(zhuǎn)來保持平衡,而旋轉(zhuǎn)是非常耗時的,由此我們可以知道AVL樹適合用于插入與刪除次數(shù)比較少,但查找多的情況。:

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(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
Int main和void main有什么區(qū)別?

一、Int main和void main有什么區(qū)別1、有無返回值void main沒有返回值,int main有返回值。2、返回值類型int main返回int類型的數(shù)據(jù),void main...詳情>>

2023-10-11 04:36:26
hash中的Key和value有什么區(qū)別?

一、hash中的Key和value的區(qū)別hash中的Key和value本意是鑰匙和值的意思,在應(yīng)用中通常被用作鍵值對,例如在map、json中等。在鍵值對中,key是關(guān)...詳情>>

2023-10-11 04:34:49
數(shù)據(jù)結(jié)構(gòu)到底是什么?

一、數(shù)據(jù)結(jié)構(gòu)到底是什么數(shù)據(jù)結(jié)構(gòu)是相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合。數(shù)據(jù)結(jié)構(gòu)包括三方面的內(nèi)容:邏輯結(jié)構(gòu)、存儲結(jié)構(gòu)和數(shù)據(jù)的運...詳情>>

2023-10-11 04:07:19
為什么要引入紅黑樹,它比普通的平衡二叉樹究竟好在哪?

一、為什么要引入紅黑樹因為AVL樹比紅黑樹更加平衡,但AVL樹在插入和刪除的時候也會存在大量的旋轉(zhuǎn)操作。所以當(dāng)你的應(yīng)用涉及到頻繁的插入和刪除...詳情>>

2023-10-11 03:54:43
數(shù)據(jù)庫系統(tǒng)的實現(xiàn)中采用了哪些常用的數(shù)據(jù)結(jié)構(gòu)?

一、數(shù)據(jù)庫系統(tǒng)的實現(xiàn)中采用的數(shù)據(jù)結(jié)構(gòu)線性表線性表結(jié)構(gòu)存儲的數(shù)據(jù)往往是可以依次排列的,就像小朋友手拉手,每位學(xué)生的前面和后面都僅有一個小...詳情>>

2023-10-11 03:43:55
快速通道