首页
/
每日頭條
/
生活
/
紅黑樹與平衡樹對比
紅黑樹與平衡樹對比
更新时间:2026-03-11 15:30:23
引言:

學過數據數據結構都知道二叉樹的概念,而又有多種比較常見的二叉樹類型,比如完全二叉樹、滿二叉樹、二叉搜索樹、均衡二叉樹、完美二叉樹等;今天我們要說的紅黑樹就是就是一顆非嚴格均衡的二叉樹,均衡二叉樹又是在二叉搜索樹的基礎上增加了自動維持平衡的性質,插入、搜索、删除的效率都比較高。紅黑樹也是實現TreeMap存儲結構的基石。

紅黑樹與平衡樹對比(紅黑樹R-Btree)1

一. 二叉搜索樹

二叉搜索樹又叫二叉查找樹、二叉排序樹,我們先看一下典型的二叉搜索樹,這樣的二叉樹有何規則特點呢?

1.節點的左子樹小于節點本身;

2.節點的右子樹大于節點本身;

3.左右子樹同樣為二叉搜索樹;

下圖就是一顆典型的二叉搜索樹

紅黑樹與平衡樹對比(紅黑樹R-Btree)2

二叉搜索樹是均衡二叉樹的基礎,我們看一下它的搜索步驟如何

我們要從二叉樹中找到值為 58 的節點

第一步:首先查找到根節點,值為60的節點

紅黑樹與平衡樹對比(紅黑樹R-Btree)3

第二步:比較我們要找的值58與該節點的大小

如果等于,那麼恭喜,已經找到;

如果小于,繼續找左子樹;

如果大于,那麼找右子樹;

很明顯58 < 60,因此我們找到左子樹的節點 56,此時我們已經定位到了節點56

紅黑樹與平衡樹對比(紅黑樹R-Btree)4

第三步:按照第二步的規則繼續找

58 > 56 我們需要繼續找右子樹,定位到了右子樹節點58,恭喜,此時我們已經找到了。

紅黑樹與平衡樹對比(紅黑樹R-Btree)5

我們經過三步就已經找到了,其實就是我們平時所說的二分查找,這種二叉搜索樹好像查找效率很高,但同樣它也有缺陷,如下面這樣的二叉搜索樹。

紅黑樹與平衡樹對比(紅黑樹R-Btree)6

看到這樣的二叉搜索樹是否很别扭,典型的大長腿瘸子,但它也是二叉搜索樹,如果我們要找值為50的節點,基本上和單鍊表查詢沒多大區别了,性能将大打折扣。這個時候我們的均衡二叉樹就粉墨登場了,均衡二叉樹就是在二叉搜索樹的基礎上添加了自動維持平衡的性質。

上面的大長腿瘸子二叉搜索樹經過自動平衡後,可能就成為了下面這樣的二叉樹。

紅黑樹與平衡樹對比(紅黑樹R-Btree)7

經過了自動平衡,再去找值為50的節點,查找性能将提升很多。紅黑樹就是非嚴格均衡的二叉搜索樹。

二. 紅黑樹規則特點

紅黑樹具體有哪些規則特點呢?

1.節點分為紅色或者黑色;

2.根節點必為黑色;

3.葉子節點都為黑色,且為null;

4.連接紅色節點的兩個子節點都為黑色(紅黑樹不會出現相鄰的紅色節點);

5.從任意節點出發,到其每個葉子節點的路徑中包含相同數量的黑色節點;

6.新加入到紅黑樹的節點為紅色節點;

規則看着好像挺多,沒錯,因為紅黑樹也是均衡二叉樹,需要具備自動維持平衡的性質,上面的6條就是紅黑樹給出的自動維持平衡所需要具備的規則

我們看一看一個典型的紅黑樹到底是什麼樣兒?

紅黑樹與平衡樹對比(紅黑樹R-Btree)8

首先解讀一下規則,除了字面上看到的意思,還隐藏了哪些意思呢?

第一. 從根節點到葉子節點的最長路徑不大于最短路徑的2倍

怎麼樣的路徑算最短路徑?

從規則5中,我們知道從根節點到每個葉子節點的黑色節點數量是一樣的,那麼純由黑色節點組成的路徑就是最短路徑;

什麼樣的路徑算是最長路徑?

根據規則4和規則3,若有紅色節點,則必然有一個連接的黑色節點,當紅色節點和黑色節點數量相同時,就是最長路徑,也就是黑色節點(或紅色節點)* 2

第二. 為什麼說新加入到紅黑樹中的節點為紅色節點

從規則4中知道,當前紅黑樹中從根節點到每個葉子節點的黑色節點數量是一樣的,此時假如新的黑色節點的話,必然破壞規則,但加入紅色節點卻不一定,除非其父節點就是紅色節點,因此加入紅色節點,破壞規則的可能性小一些,下面我們也會舉例來說明。

什麼情況下,紅黑樹的結構會被破壞呢?破壞後又怎麼維持平衡,維持平衡主要通過兩種方式【變色】和【旋轉】,【旋轉】又分【左旋】和【右旋】,兩種方式可相互結合。

下面我們從插入和删除兩種場景來舉例說明

因為文章過長不能一一上傳編寫,所以整理成了PDF文檔,想要獲取的小夥伴的朋友,可以私信我關鍵字【資料】進行獲取。

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
鐵皮石斛泡水喝方法
鐵皮石斛泡水喝方法
1、我們也不需要用太多的石斛,一次取個四五個就可以。2、将它放在容器裡面,不管是玻璃杯還是瓷杯都可以...
2026-03-11
此卡存在快捷支付合約不能重複簽約什麼意思
此卡存在快捷支付合約不能重複簽約什麼意思
1、此卡存在快捷支付合約不能重複簽約是指賬戶已經和銀行簽訂網銀關系,可以在網上登入。2、在網上自助開...
2026-03-11
熟米飯在冷藏能放幾天
熟米飯在冷藏能放幾天
1、如果将剩飯在冷卻之後再放入冰箱的話,就可以起到抑制細菌的效果,讓食物的腐敗速度變慢,這樣下次就可以繼續吃。在冷藏室放置不宜超過3、4天,且冷藏室的溫度不宜高于4度。2、剩下的米飯不應該存放在原來的大鍋裡,因為大鍋不方便冷凍,所以最好把剩下的白米放在小鍋裡,然後放到冰箱裡冷凍。3、冷卻的米飯被蓋好...
2026-03-11
草莓幹做法步驟
草莓幹做法步驟
1、用料:新鮮的草莓600克、食鹽适量(用來清洗草莓的)。2、首先草莓先用流水沖一遍,然後加點鹽巴浸...
2026-03-11
裝修公司如何選擇
裝修公司如何選擇
1、首先應該知道裝修公司的分類,裝修公司一般分為設計優良、施工精細的裝修工作室;名氣大、規模大的超大型的裝修公司、公司整體規模大、但在當地不一定很出名的全國連鎖型公司;當地的二、三流裝修公司;最後一種是路邊的裝修遊擊隊。2、初選裝修公司可通過哪些渠道來找?在初選裝修公司時,業主們一定要利用要一切可以...
2026-03-11
Copyright 2023-2026 - www.tftnews.com All Rights Reserved