1、首先,需要定義紅黑樹的節(jié)點這樣的結(jié)構(gòu)。
察哈爾右翼中旗網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)公司從2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
2、定義結(jié)構(gòu)的順序。
3、然后,就能在這里定義的根節(jié)點的結(jié)構(gòu)體。
4、此時,可以暫時這棵紅黑樹的根命名為rb_root。
5、這時,利用剛剛定義的紅黑樹節(jié)點定義新節(jié)點。
6、最后,我們便可以為其重新命名為RBRoot即可。
首先,不推薦使用[]來判斷key是否存在,因為使用操作符[]會向map容器里插入一個元素.map的operator[]重載大致是這樣一個內(nèi)容:
data_type operator[]( const key_type k ){value_type v(k,data_type());
iterator it = insert(v).first;
} 大致是這樣,如果沒有找到的話就插入一個,然后返回它的second.正確的判斷方法是使用map的find函數(shù),由于map是一個紅黑樹,find的時間復(fù)雜度是logn,可以接受.bool i***ist(constString keyName) { return( mRegistryMap.find(keyName)!= mRegistryMap.end()); }
紅黑樹和AVL樹一樣都對插入時間、刪除時間和查找時間提供了最好可能的最壞情況擔保。這不只是使它們在時間敏感的應(yīng)用如即時應(yīng)用(real time application)中有價值,而且使它們有在提供最壞情況擔保的其他數(shù)據(jù)結(jié)構(gòu)中作為建造板塊的價值;例如,在計算幾何中使用的很多數(shù)據(jù)結(jié)構(gòu)都可以基于紅黑樹。
紅黑樹在函數(shù)式編程中也特別有用,在這里它們是最常用的持久數(shù)據(jù)結(jié)構(gòu)之一,它們用來構(gòu)造關(guān)聯(lián)數(shù)組和集合,在突變之后它們能保持為以前的版本。除了O(log n)的時間之外,紅黑樹的持久版本對每次插入或刪除需要O(log n)的空間。
紅黑樹是 2-3-4樹的一種等同。換句話說,對于每個 2-3-4 樹,都存在至少一個數(shù)據(jù)元素是同樣次序的紅黑樹。在 2-3-4 樹上的插入和刪除操作也等同于在紅黑樹中顏色翻轉(zhuǎn)和旋轉(zhuǎn)。這使得 2-3-4 樹成為理解紅黑樹背后的邏輯的重要工具,這也是很多介紹算法的教科書在紅黑樹之前介紹 2-3-4 樹的原因,盡管 2-3-4 樹在實踐中不經(jīng)常使用。