原文:說說紅黑樹——不談操作,只講理解

一 前言 這幾天想學一學紅黑樹這種數據結構,於是上網找了很多篇博客,初看嚇了一跳,紅黑樹竟然如此復雜。連續看了幾篇博客后,算是對紅黑樹有了一些了解,但是它的原理卻並不是特別理解。網上的博客,千篇一律的都是在敘述紅黑樹的操作,如何插入節點 刪除節點,旋轉 變色等,只關注如何正確構建一棵紅黑樹,但是卻很少提及為什么這么做。這篇博客我就來記錄一些我所知道的紅黑樹中比較重要的東西,以及談一談我的理解。 我 ...

2020-03-24 02:39 1 579 推薦指數:

查看詳情

關於旋轉的理解

概述 的左旋和右旋比較費解,網上很多資料說的很復雜,這里我用望文生義的思維來解釋左旋和右旋。可能對搜索資料的網友有幫助。 二叉查找的定義 二叉查找是一棵空,或者是具有下列性質的二叉樹:1、若左子樹不空,則左子樹上所有節點的值均小於它的根節點的值;2、若右子樹不空,則右子樹上所有 ...

Sun Sep 15 04:05:00 CST 2019 2 1792
的本質出發,徹底理解

前言 早上好,我是彤哥。 上一節,我們一起從二叉樹、二叉查找、平衡、AVL、2-3、2-3-4、B,一路講到,最后得出的本質:就是2-3-4,請看下圖: 我們知道2-3-4的插入、刪除、查找元素的原理是相當簡單的,那么,我們是不是可以利用2-3-4來記憶 ...

Mon Oct 12 15:41:00 CST 2020 1 1295
了解的起源,理解的本質

前言 本文收錄於專輯:http://dwz.win/HjK,點擊解鎖更多數據結構與算法的知識。 你好,我是彤哥。 前面兩節,我們一起學習了關於跳表的理論知識,並手寫了兩種完全不同的實現 ...

Fri Sep 18 06:11:00 CST 2020 0 1082
刪除操作

若被刪除的結點有兩個非葉子結點,那么可以轉換為刪除一個“替代點”的問題,該替代點最多只有一個非葉子孩子結點。可以通過前驅或者后繼(都最多有一個非葉子孩子結點)來替代最初要被刪除的結點,所以下面關注只有一個非葉子孩子結點的問題,一旦我們解決了這個問題,那么解決方法將同樣適用於兩種情形:1、原本 ...

Tue Jan 19 07:34:00 CST 2016 2 1368
刪除操作

查閱了很多的資料,最終把的刪除操作弄明白。為方便日后溫習,也為那些正想弄明白但又苦苦明白不了該操作詳細原理的同學查閱,特將其當筆記記錄下來。下面內容是個人所理解的刪除操作,如果有不對的地方,歡迎各路大神指正。 的刪除操作 1:節點命名約定 D表示要被 ...

Thu May 05 17:36:00 CST 2016 21 12562
通過2-3-4理解

code[class*="language-"], pre[class*="language-"] { background-color: #fdfdfd; -webkit-box-sizi ...

Thu Jan 04 03:39:00 CST 2018 5 4279
通過2-3理解

操作維護了一棵平衡的二分搜索。本章節我們繼續梳理一個高階的樹結構即:。想必大家都知道,如 ...

Fri Aug 30 06:15:00 CST 2019 4 1814
對AVL的個人理解

都說編程算法很重要,可真沒見幾個.NET程序員研究算法的。這些日子非主流地研究了一些小算法,和AVL算是其中復雜的了,但實際也就二三百行代碼。悲催的是,網上根本找不到C#的理想版本(包括國外網站),寥寥幾個,要么有錯,要么非主流的實現方式。 所謂主流方式,就是用表二叉排序樹 ...

Thu Jun 07 00:25:00 CST 2012 4 16800
 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM