




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第Python二叉樹初識(新手也秒懂!)目錄樹術(shù)語二叉樹特殊二叉樹滿二叉樹:完全二叉樹:完全二叉樹性質(zhì):其他特殊二叉樹二叉樹的遍歷先序遍歷中序遍歷后序遍歷層序遍歷Python實現(xiàn)二叉樹二叉樹第三方庫binarytree使用環(huán)境與安裝簡單實例總結(jié)
樹
樹(Tree)是n(n0)個節(jié)點的有限集。
在任意一棵樹中:
(1)有且僅有一個特定的稱為根(Root)的節(jié)點;
(2)當(dāng)n>1時,其余節(jié)點可分m(m>0)為個互不相交的有限集T1,T2,...,Tm;
其中每一個集合本身又是一棵樹,并且稱為根的子樹(SubTree)。
Tree:
--------------------
Height=4Leves=5Root
Degree=3Size=26↙
___________________17____________NodeLevel1
//\↙
26______2___9__-ChildLevel2
/\\//\
___019_3___6___2115Level3
//\/\/\
7_16_24_810423Level4
/\//\/\/\
5112813127291822Level5
__________...LeafLeftChildRightChild
術(shù)語
節(jié)點:包含一個數(shù)據(jù)元素及若干指向其子樹的分支,又的譯成結(jié)點(Node)
根:樹和子樹的頂點(Root)
度:節(jié)點擁有的子樹數(shù)量稱為節(jié)點的度(Degree);樹的度是指樹內(nèi)個結(jié)點的度的最大值
分支節(jié)點:度不為0的節(jié)點
葉子:沒有子樹的節(jié)點,即它的度為0(Leaf)
子節(jié)點:結(jié)點的子樹的根稱為該節(jié)點的孩子(Child)
父節(jié)點:對應(yīng)子節(jié)點上一層(level)節(jié)點稱為該節(jié)點的雙親(Parent)
兄弟結(jié)點:同一父節(jié)點的子節(jié)點,互稱兄弟(Sibling)
節(jié)點的祖先:是從根到該結(jié)點所經(jīng)分支上的所有節(jié)點
節(jié)點的子孫:以某結(jié)點為根的子樹中的所有節(jié)點
層:從根開始,根為第一層,根的孩子為第二層...(Level)
深度:樹中結(jié)點的最大層次數(shù),稱為樹的深度或高度(DepthorHeight)
森林:是很多互不相交的樹的集合(Forest)
無序樹:樹中任意節(jié)點的子節(jié)點之間沒有順序關(guān)系,這種樹稱為無序樹,也稱為自由樹
有序樹:樹中任意節(jié)點的子節(jié)點之間有順序關(guān)系,這種樹稱為有序樹
最大樹(最小樹):每個結(jié)點的值都大于(小于)或等于其子結(jié)點(如果有的話)值的樹
二叉樹
二叉樹(BinaryTree)是一種特殊的有序樹型結(jié)構(gòu)。
特點:
(1)每個節(jié)點至多有兩棵子樹;
(2)二叉樹的子樹有左右之分;
(3)子樹的次序不能任意顛倒(有序樹)。
性質(zhì):
(1)在二叉樹的第i層上至多有2^(i-1)個節(jié)點(i=1);
(2)深度為k的二叉樹至多有2^k-1個節(jié)點(k=1);
(3)對任何一棵二叉樹,如果其葉子節(jié)點數(shù)為N0,度為2的結(jié)點數(shù)為N2,則N0=N2+1。
特殊二叉樹
滿二叉樹:
所有層的節(jié)點都達到最大數(shù)量,葉子除外的所有節(jié)點都有兩個子節(jié)點,所有葉子都在最底一層(k)且數(shù)目為2^(k-1)。即深度k且有2^k-1個節(jié)點(葉子長滿最后一層),或稱完美二叉樹(PerfectBinaryTree)
______12_______
/\
__3____5__
/\/\
_76_911
/\/\/\/\
完全二叉樹:
如果刪除最底一層的所有葉子它就是滿二叉樹,即除了最后一層,每層節(jié)點都達到最大數(shù)量,即有深度k的個節(jié)點數(shù)在左閉右開【2^(k-1)+1,2^k-1】區(qū)間內(nèi)。(CompleteBinaryTree)
________3______
/\
___11_____4__
/\/\
147913
/\/\/
25861
完全二叉樹性質(zhì):
1.具有N個節(jié)點的完全二叉樹的深度為[log2N]+1,其中[x]為高斯函數(shù),截尾取整。
2.如果對一棵有n個節(jié)點的完全二叉樹的節(jié)點按層序編號(從第一層到最后一層,每層從左到右),則對任一節(jié)點,有:
(1)如果i=1,則節(jié)點i是二叉樹的根,無雙親;如果i1,則其雙親節(jié)點為[i/2];
(2)如果2in,則節(jié)點i無左孩子;否則其左孩子是節(jié)點2i;
(3)如果2i+1n,則節(jié)點i無右孩子;否則其右孩子是節(jié)點2i+1。
其他特殊二叉樹
排序二叉樹
二叉查找樹(BinarySearchTree),也稱二叉搜索樹或有序二叉樹
平衡二叉樹
左右子樹的高度差不大于1的二叉樹,且一定有:它的左、右子樹也都是平衡二叉樹(Self-BalancingBinarySearchTree)
退化樹
退化樹是每個節(jié)點都只有一個孩子的樹,孩子或左或右,或稱病態(tài)樹
斜二叉樹
一種特殊的退化樹,其中全部節(jié)點只有左孩子或右孩子,分別稱左斜二叉樹和右斜二叉樹,功能基本上退化到和鏈表一樣了
霍夫曼樹
帶權(quán)路徑最短的二叉樹稱為哈夫曼樹或最優(yōu)二叉樹
B樹
一種對讀寫操作進行優(yōu)化的自平衡的二叉樹查找,能夠保持數(shù)據(jù)有序,擁有多余兩個子樹
堆heap
binaryheap是一種完全二叉樹,除了最底層的葉子節(jié)點之外,是填滿的;而且最底層的葉子節(jié)點從左至右是連續(xù)的,不得有空隙。最大堆(最小堆)就是最大(最小)的完全二叉樹。
二叉樹的遍歷
指如何按某種搜索路徑巡防樹中的每個結(jié)點,使得每個結(jié)點均被訪問一次,而且僅被訪問一次。
常見的遍歷方法有:先序遍歷,中序遍歷,后序遍歷,層序遍歷;一般都使用遞歸算法來實現(xiàn)。
以滿二叉樹為例:
_______1________
/\
__2_____3___
/\/\
45_6_7
/\/\/\/\
89101112131415
先序遍歷
若二叉樹為空,為空操作;
否則(1)訪問根節(jié)點;(2)先序遍歷左子樹;(3)先序遍歷右子樹。
遍歷結(jié)果:1[2[489][51011]][3[61213][71415]根左右
中序遍歷
若二叉樹為空,為空操作;
否則(1)中序遍歷左子樹;(2)訪問根結(jié)點;(3)中序遍歷右子樹。
遍歷結(jié)果:[[849]2[10511]]1[[12613]3[14715]]左根右
后序遍歷
若二叉樹為空,為空操作;
否則(1)后序遍歷左子樹;(2)后序遍歷右子樹;(3)訪問根結(jié)點。
遍歷結(jié)果:[[894][10115]2][[12136][14157]3]1左右根
層序遍歷
若二叉樹為空,為空操作;否則從上到下、從左到右按層次進行訪問。
遍歷結(jié)果:1[23][4567][89101112131415]
非滿二叉樹的遍歷結(jié)果:
________1________
/\
__2______3
/\/\
4_567
\/\/\
910111215
先序:1[2[49][51011]][3[612][715]]
中序:[49]2[10511]1[126]3[715]
后序:[[94][10115]2][[126][157]3]1
層序:1[23][4567][910111215]
注:結(jié)果中只是標(biāo)記相對于滿二叉樹缺失的子節(jié)點,實際結(jié)果并不展現(xiàn)。
Python實現(xiàn)二叉樹
用Python簡單實現(xiàn)如下二叉樹的遍歷功能,并列出層數(shù)和所有葉子:
______A______
/\
__B____C__
/\/\
DEFG
/\/\\\
HIJKLM
代碼如下:
classNode():
def__init__(self,data=None,left=None,right=None):
self.data=data
self.left=left
self.right=right
defPreorder(self):
ifself.dataisnotNone:
print(self.data,end='')
ifself.leftisnotNone:
self.left.Preorder()
ifself.rightisnotNone:
self.right.Preorder()
defInorder(self):
ifself.leftisnotNone:
self.left.Inorder()
ifself.dataisnotNone:
print(self.data,end='')
ifself.rightisnotNone:
self.right.Inorder()
defPostorder(self):
ifself.leftisnotNone:
self.left.Postorder()
ifself.rightisnotNone:
self.right.Postorder()
ifself.dataisnotNone:
print(self.data,end='')
defHeight(self):
ifself.dataisNone:
return0
elifnotany([self.left,self.right]):
return1
elifall([notself.left,self.right]):
returnself.right.Height()+1
elifall([self.left,notself.right]):
returnself.left.Height()+1
else:
returnmax(self.left.Height(),self.right.Height())+1
defLeaves(self):
ifsel
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 機場設(shè)施叉車吊裝運輸安全協(xié)議范本
- 四害防治服務(wù)合同范本及注意事項
- 可視化健康監(jiān)測膠囊行業(yè)分析
- 超導(dǎo)透明材料技術(shù)未來展望
- 2025至2030中國塑料薄膜行業(yè)項目調(diào)研及市場前景預(yù)測評估報告
- 2025至2030中國眾籌行業(yè)市場發(fā)展分析及典型案例及有效策略與實施路徑評估報告
- 科研機構(gòu)技術(shù)人員培訓(xùn)計劃
- 2025至2030中國自行車胎和輪胎行業(yè)市場深度研究及發(fā)展前景投資可行性分析報告
- 心理學(xué)教學(xué)改革心得體會
- 2025至2030中國自動閘門操作員行業(yè)市場占有率及投資前景評估規(guī)劃報告
- 2024-2025學(xué)年人教版PEP六年級下學(xué)期期末試卷(含答案含聽力原文無音頻)
- 2025-2030年中國聚脲涂料行業(yè)市場現(xiàn)狀供需分析及投資評估規(guī)劃分析研究報告
- 一級建造師考試安全管理試題及答案
- 《成人糖尿病患者的高血糖危象:共識報告》-學(xué)習(xí)與應(yīng)用
- 鍍鋅板知識課件
- 2025-2030偏光成像相機行業(yè)市場現(xiàn)狀供需分析及重點企業(yè)投資評估規(guī)劃分析研究報告
- 腦卒中急救培訓(xùn)課件
- 豬場退股協(xié)議書范本
- 2025海南保亭農(nóng)水投資有限公司招聘22人筆試參考題庫附帶答案詳解
- 靜密封管理制度
- AI人工智能在金融領(lǐng)域的應(yīng)用案例
評論
0/150
提交評論