




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第Python二叉樹初識(新手也秒懂!)目錄樹術(shù)語二叉樹特殊二叉樹滿二叉樹:完全二叉樹:完全二叉樹性質(zhì):其他特殊二叉樹二叉樹的遍歷先序遍歷中序遍歷后序遍歷層序遍歷Python實(shí)現(xiàn)二叉樹二叉樹第三方庫binarytree使用環(huán)境與安裝簡單實(shí)例總結(jié)
樹
樹(Tree)是n(n0)個(gè)節(jié)點(diǎn)的有限集。
在任意一棵樹中:
(1)有且僅有一個(gè)特定的稱為根(Root)的節(jié)點(diǎn);
(2)當(dāng)n>1時(shí),其余節(jié)點(diǎn)可分m(m>0)為個(gè)互不相交的有限集T1,T2,...,Tm;
其中每一個(gè)集合本身又是一棵樹,并且稱為根的子樹(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é)點(diǎn):包含一個(gè)數(shù)據(jù)元素及若干指向其子樹的分支,又的譯成結(jié)點(diǎn)(Node)
根:樹和子樹的頂點(diǎn)(Root)
度:節(jié)點(diǎn)擁有的子樹數(shù)量稱為節(jié)點(diǎn)的度(Degree);樹的度是指樹內(nèi)個(gè)結(jié)點(diǎn)的度的最大值
分支節(jié)點(diǎn):度不為0的節(jié)點(diǎn)
葉子:沒有子樹的節(jié)點(diǎn),即它的度為0(Leaf)
子節(jié)點(diǎn):結(jié)點(diǎn)的子樹的根稱為該節(jié)點(diǎn)的孩子(Child)
父節(jié)點(diǎn):對應(yīng)子節(jié)點(diǎn)上一層(level)節(jié)點(diǎn)稱為該節(jié)點(diǎn)的雙親(Parent)
兄弟結(jié)點(diǎn):同一父節(jié)點(diǎn)的子節(jié)點(diǎn),互稱兄弟(Sibling)
節(jié)點(diǎn)的祖先:是從根到該結(jié)點(diǎn)所經(jīng)分支上的所有節(jié)點(diǎn)
節(jié)點(diǎn)的子孫:以某結(jié)點(diǎn)為根的子樹中的所有節(jié)點(diǎn)
層:從根開始,根為第一層,根的孩子為第二層...(Level)
深度:樹中結(jié)點(diǎn)的最大層次數(shù),稱為樹的深度或高度(DepthorHeight)
森林:是很多互不相交的樹的集合(Forest)
無序樹:樹中任意節(jié)點(diǎn)的子節(jié)點(diǎn)之間沒有順序關(guān)系,這種樹稱為無序樹,也稱為自由樹
有序樹:樹中任意節(jié)點(diǎn)的子節(jié)點(diǎn)之間有順序關(guān)系,這種樹稱為有序樹
最大樹(最小樹):每個(gè)結(jié)點(diǎn)的值都大于(小于)或等于其子結(jié)點(diǎn)(如果有的話)值的樹
二叉樹
二叉樹(BinaryTree)是一種特殊的有序樹型結(jié)構(gòu)。
特點(diǎn):
(1)每個(gè)節(jié)點(diǎn)至多有兩棵子樹;
(2)二叉樹的子樹有左右之分;
(3)子樹的次序不能任意顛倒(有序樹)。
性質(zhì):
(1)在二叉樹的第i層上至多有2^(i-1)個(gè)節(jié)點(diǎn)(i=1);
(2)深度為k的二叉樹至多有2^k-1個(gè)節(jié)點(diǎn)(k=1);
(3)對任何一棵二叉樹,如果其葉子節(jié)點(diǎn)數(shù)為N0,度為2的結(jié)點(diǎn)數(shù)為N2,則N0=N2+1。
特殊二叉樹
滿二叉樹:
所有層的節(jié)點(diǎn)都達(dá)到最大數(shù)量,葉子除外的所有節(jié)點(diǎn)都有兩個(gè)子節(jié)點(diǎn),所有葉子都在最底一層(k)且數(shù)目為2^(k-1)。即深度k且有2^k-1個(gè)節(jié)點(diǎn)(葉子長滿最后一層),或稱完美二叉樹(PerfectBinaryTree)
______12_______
/\
__3____5__
/\/\
_76_911
/\/\/\/\
完全二叉樹:
如果刪除最底一層的所有葉子它就是滿二叉樹,即除了最后一層,每層節(jié)點(diǎn)都達(dá)到最大數(shù)量,即有深度k的個(gè)節(jié)點(diǎn)數(shù)在左閉右開【2^(k-1)+1,2^k-1】區(qū)間內(nèi)。(CompleteBinaryTree)
________3______
/\
___11_____4__
/\/\
147913
/\/\/
25861
完全二叉樹性質(zhì):
1.具有N個(gè)節(jié)點(diǎn)的完全二叉樹的深度為[log2N]+1,其中[x]為高斯函數(shù),截尾取整。
2.如果對一棵有n個(gè)節(jié)點(diǎn)的完全二叉樹的節(jié)點(diǎn)按層序編號(從第一層到最后一層,每層從左到右),則對任一節(jié)點(diǎn),有:
(1)如果i=1,則節(jié)點(diǎn)i是二叉樹的根,無雙親;如果i1,則其雙親節(jié)點(diǎn)為[i/2];
(2)如果2in,則節(jié)點(diǎn)i無左孩子;否則其左孩子是節(jié)點(diǎn)2i;
(3)如果2i+1n,則節(jié)點(diǎn)i無右孩子;否則其右孩子是節(jié)點(diǎn)2i+1。
其他特殊二叉樹
排序二叉樹
二叉查找樹(BinarySearchTree),也稱二叉搜索樹或有序二叉樹
平衡二叉樹
左右子樹的高度差不大于1的二叉樹,且一定有:它的左、右子樹也都是平衡二叉樹(Self-BalancingBinarySearchTree)
退化樹
退化樹是每個(gè)節(jié)點(diǎn)都只有一個(gè)孩子的樹,孩子或左或右,或稱病態(tài)樹
斜二叉樹
一種特殊的退化樹,其中全部節(jié)點(diǎn)只有左孩子或右孩子,分別稱左斜二叉樹和右斜二叉樹,功能基本上退化到和鏈表一樣了
霍夫曼樹
帶權(quán)路徑最短的二叉樹稱為哈夫曼樹或最優(yōu)二叉樹
B樹
一種對讀寫操作進(jìn)行優(yōu)化的自平衡的二叉樹查找,能夠保持?jǐn)?shù)據(jù)有序,擁有多余兩個(gè)子樹
堆heap
binaryheap是一種完全二叉樹,除了最底層的葉子節(jié)點(diǎn)之外,是填滿的;而且最底層的葉子節(jié)點(diǎn)從左至右是連續(xù)的,不得有空隙。最大堆(最小堆)就是最大(最?。┑耐耆鏄?。
二叉樹的遍歷
指如何按某種搜索路徑巡防樹中的每個(gè)結(jié)點(diǎn),使得每個(gè)結(jié)點(diǎn)均被訪問一次,而且僅被訪問一次。
常見的遍歷方法有:先序遍歷,中序遍歷,后序遍歷,層序遍歷;一般都使用遞歸算法來實(shí)現(xiàn)。
以滿二叉樹為例:
_______1________
/\
__2_____3___
/\/\
45_6_7
/\/\/\/\
89101112131415
先序遍歷
若二叉樹為空,為空操作;
否則(1)訪問根節(jié)點(diǎn);(2)先序遍歷左子樹;(3)先序遍歷右子樹。
遍歷結(jié)果:1[2[489][51011]][3[61213][71415]根左右
中序遍歷
若二叉樹為空,為空操作;
否則(1)中序遍歷左子樹;(2)訪問根結(jié)點(diǎn);(3)中序遍歷右子樹。
遍歷結(jié)果:[[849]2[10511]]1[[12613]3[14715]]左根右
后序遍歷
若二叉樹為空,為空操作;
否則(1)后序遍歷左子樹;(2)后序遍歷右子樹;(3)訪問根結(jié)點(diǎn)。
遍歷結(jié)果:[[894][10115]2][[12136][14157]3]1左右根
層序遍歷
若二叉樹為空,為空操作;否則從上到下、從左到右按層次進(jìn)行訪問。
遍歷結(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é)點(diǎn),實(shí)際結(jié)果并不展現(xiàn)。
Python實(shí)現(xiàn)二叉樹
用Python簡單實(shí)現(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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 農(nóng)業(yè)生物技術(shù)研發(fā)及應(yīng)用推廣合同書
- 軟件設(shè)計(jì)類合同協(xié)議
- 遺產(chǎn)放棄協(xié)議書范本
- 農(nóng)業(yè)合作社種植與養(yǎng)殖一體化協(xié)議
- 運(yùn)動(dòng)館經(jīng)營合同協(xié)議
- 文員勞動(dòng)用工合同
- 網(wǎng)絡(luò)輿情監(jiān)測與應(yīng)對措施制定指南
- 音樂史與音樂欣賞能力測試
- 婚姻撫養(yǎng)費(fèi)協(xié)議書
- 燈具維修協(xié)議書
- 2023年設(shè)備檢修標(biāo)準(zhǔn)化作業(yè)規(guī)范
- GB/T 20001.1-2024標(biāo)準(zhǔn)起草規(guī)則第1部分:術(shù)語
- 工筆花鳥學(xué)習(xí)心得范文
- 2024年度《兒童生長發(fā)育》課件
- 初中生機(jī)器人課程課件
- 呼吸機(jī)的常見故障
- 肺結(jié)核患者的心理支持和護(hù)理
- 6.船舶電氣與自動(dòng)化(船舶自動(dòng)化)(二三管輪)
- 2023年新高考全國Ⅱ卷英語試題真題及答案詳解(含作文范文)
- 河南近10年中考真題物理含答案(2023-2014)
- 浙江萬盛股份有限公司年產(chǎn)43500噸磷酸酯無鹵阻燃劑及副產(chǎn)43000噸30%鹽酸、含氯化鈉鹽等裝備提升技改項(xiàng)目、年產(chǎn)10000噸氯丁烷技改項(xiàng)目、年產(chǎn)6000噸復(fù)配型阻燃劑項(xiàng)目環(huán)評報(bào)告
評論
0/150
提交評論