首页
/
每日頭條
/
生活
/
平衡二叉樹所有類型
平衡二叉樹所有類型
更新时间:2026-06-11 19:58:08

在按照二叉查找樹(二叉查找樹(BST:Binary Search Tree) )的方式插入元素構建一個平衡二叉樹(平衡二叉樹 )時,可能會出現不平衡的現象。可以根據新插入節點與最低不平衡節點之間的位置關系進行相應的調整。

我們先把需要調整的類型分為四種情況:LL型、RR型、LR型、RL型。使用圖形示例與實際代碼結合的方式對不平衡二叉樹進行旋轉。

定義一個樹節點:

平衡二叉樹所有類型(不平衡二叉樹的旋轉)1

平衡二叉樹節點定義

LL型調整

由于在y_6的左孩子(L)的左子樹(L)上插入新結點2,使原來平衡二叉樹變得不平衡,此時y_6的平衡因子由1增至2。顯然,按照大小關系,結點x_3應作為新的根結點,1和y_6兩個節點分别作為左右孩子節點才能平衡,y_6結點就好像是繞結點x_3順時針旋轉一樣。

平衡二叉樹所有類型(不平衡二叉樹的旋轉)2

LL型調整

總結一下LL型調整的一般步驟:

  1. 将y_6(新的不平衡節點)的左孩子x_3提升為新的根節點;
  2. 将原來的根節點y_6降為x_3的右孩子
  3. 各子樹按照大小關系連接(y_6的右孩子,x_3的左孩子不變,x_3的右孩子調整為y_6的左孩子)

平衡二叉樹所有類型(不平衡二叉樹的旋轉)3

LL型旋轉代碼實現

RR型調整

由于在y_2的右孩子(R)的右子樹(L)上插入新結點5,使原來平衡二叉樹變得不平衡,此時y_2的平衡因子由1增至2。顯然,按照大小關系,結點x_4應作為新的根結點,y_2和6兩個節點分别作為左右孩子節點才能平衡,y_2結點就好像是繞結點x_4逆時針旋轉一樣。

平衡二叉樹所有類型(不平衡二叉樹的旋轉)4

RR型調整

總結一下RR型調整的一般步驟:

  1. 将y_2(新的不平衡節點)的右孩子x_4提升為新的根節點;
  2. 将原來的根節點y_2降為x_4的左孩子
  3. 各子樹按照大小關系連接(y_6的左孩子,x_4的右孩子不變,x_4的左孩子調整為y_2的右孩子)

平衡二叉樹所有類型(不平衡二叉樹的旋轉)5

RR型旋轉代碼實現

LR型調整

由于在6的左孩子(L)的右子樹(R)上插入新結點3,使原來平衡二叉樹變得不平衡,此時6的平衡因子由1增至2。顯然,按照大小關系,結點x_4應作為新的根結點,y_2和6兩個節點分别作為左右孩子節點才能平衡。

平衡二叉樹所有類型(不平衡二叉樹的旋轉)6

LR型調整

總結一下LR型調整的一般步驟:

  1. 将y_2假設為新的根節點;
  2. 将以y_2為根的二叉樹進行RR型旋轉;
  3. 再對以y_6為根的二叉樹進行LL型旋轉;

平衡二叉樹所有類型(不平衡二叉樹的旋轉)7

LR型旋轉代碼實現

RL型調整

由于在2的右孩子(R)的左子樹(L)上插入新結點4,使原來平衡二叉樹變得不平衡,此時2的平衡因子由1增至2。顯然,按照大小關系,結點3應作為新的根結點,2和5兩個節點分别作為左右孩子節點才能平衡。

平衡二叉樹所有類型(不平衡二叉樹的旋轉)8

RL型調整

總結一下RL型調整的一般步驟:

  1. 将x_5假設為新的根節點;
  2. 将以x_5為根的二叉樹進行LL型旋轉;
  3. 再對以y_2為根的二叉樹進行RR型旋轉;

平衡二叉樹所有類型(不平衡二叉樹的旋轉)9

RL型旋轉代碼實現

理解好平衡二叉樹的旋轉,對後邊學習紅黑樹有非常大的幫助。下一篇文章學習,如何在構建和删除平衡二叉樹的過程中維持二叉樹一直平衡。

平衡二叉樹

如何優雅地畫好二叉樹

二叉樹遍曆的思維導圖

二叉樹的層序遍曆及應用

二叉查找樹(BST:Binary Search Tree)

,
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
推荐阅读
怎麼知道一段緣分是不是正緣
怎麼知道一段緣分是不是正緣
一對戀人從相識到相知相愛,其實是有一定預兆的。隻是預兆很輕微,往往被我們粗心略過。很多時候,當你往回看時,才發現一切都好像是命中注定,從命理上來說,這就是“緣分”。呂泉老師--身心靈療愈師能夠擁有一份不錯的愛情,這是每個人的心聲。但是有時候...
2026-06-11
對郦波講詩的評價
對郦波講詩的評價
對郦波講詩的評價?這個争論有一段時間了現在看出來,這件事的本質并不在于論郦詩的好壞,而是在于有一種争名奪利,博人眼球的勝負心在其中作怪,是一個典型的借名人之名而出名的例子這個看看事件過程即可明曉,現在小編就來說說關于對郦波講詩的評價?下面内...
2026-06-11
阿凡達2上映時間多長
阿凡達2上映時間多長
距離《阿凡達》首映已經過去了13年,全球矚目的續集《阿凡達:水之道》(以下稱《阿凡達2》)終于要和觀衆見面了,目前該片已定檔今年12月16日北美上映。《阿凡達2》仍由“卡神”詹姆斯·卡梅隆執導,薩姆·沃辛頓、佐伊·索爾達娜、西格妮·韋弗領銜...
2026-06-11
看美劇學英語推薦美劇零基礎
看美劇學英語推薦美劇零基礎
,
2026-06-11
西遊記十四回概括
西遊記十四回概括
西遊記十四回概括?劉伯欽送唐僧到兩屆山,救出了孫悟空,師徒别劉伯欽西行途中寄宿遇見六個山賊(分别是:眼看喜,耳聽怒,鼻嗅愛,舌嘗思,意見欲,身本憂代表人的六種感官享受),悟空殺死六賊,唐僧責怪悟空殺人,于是悟空撇下唐僧,接下來我們就來聊聊關...
2026-06-11
Copyright 2023-2026 - www.tftnews.com All Rights Reserved