數(shù)據(jù)結構-用面向對象語言描述-殷人昆-第五章_第1頁
數(shù)據(jù)結構-用面向對象語言描述-殷人昆-第五章_第2頁
數(shù)據(jù)結構-用面向對象語言描述-殷人昆-第五章_第3頁
數(shù)據(jù)結構-用面向對象語言描述-殷人昆-第五章_第4頁
數(shù)據(jù)結構-用面向對象語言描述-殷人昆-第五章_第5頁
已閱讀5頁,還剩48頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

第五章樹與二叉樹數(shù)據(jù)結構電子教案主講:楊同峰1第五章樹與二叉樹樹和森林的概念二叉樹二叉樹遍歷二叉樹的計數(shù)樹與森林堆Huffman樹2有根樹: 一棵有根樹T,簡稱為樹,它是n(n≥0)

個結點的有限集合。當n=0時,T稱為空樹;否則,T

是非空樹,記作

樹和森林的概念3

r是一個特定的稱為根(root)的結點,它只有直接后繼,但沒有直接前驅;根以外的其他結點劃分為m(m

0)個互不相交的有限集合T1,T2,…,Tm,每個集合又是一棵樹,并且稱之為根的子樹。每棵子樹的根結點有且僅有一個直接前驅,但可以有0個或多個直接后繼。4樹的基本術語子女:若結點的子樹非空,結點子樹的根即為該結點的子女。雙親:若結點有子女,該結點是子女的雙親。1層2層4層3層depth=4DACBIJHGFEMLKheight=45兄弟:同一結點的子女互稱為兄弟。度:結點的子女個數(shù)即為該結點的度;樹中各個結點的度的最大值稱為樹的度。分支結點:度不為0的結點即為分支結點,亦稱為非終端結點。葉結點:度為0的結點即為葉結點,亦稱為終端結點。祖先:某結點到根結點的路徑上的各個結點都是該結點的祖先。子孫:某結點的所有下屬結點,都是該結點的子孫。6結點的層次:規(guī)定根結點在第一層,其子女結點的層次等于它的層次加一。以下類推。深度:結點的深度即為結點的層次;離根最遠結點的層次即為樹的深度。1層2層4層3層depth=4DACBIJHGFEMLKheight=47有序樹:樹中結點的各棵子樹T0,T1,…是有次序的,即為有序樹。無序樹:樹中結點的各棵子樹之間的次序是不重要的,可以互相交換位置。森林:森林是m(m≥0)棵樹的集合。

8二叉樹的五種不同形態(tài)LLRR二叉樹(BinaryTree)二叉樹的定義

一棵二叉樹是結點的一個有限集合,該集合或者為空,或者是由一個根結點加上兩棵分別稱為左子樹和右子樹的、互不相交的二叉樹組成。9二叉樹的性質(zhì)性質(zhì)1

若二叉樹結點的層次從1開始,則在二叉樹的第i層最多有

2i-1

個結點。(i≥1)

[證明用數(shù)學歸納法]性質(zhì)2

深度為k

的二叉樹最少有k

個結點,最多有2k-1個結點。(k≥1)

因為每一層最少要有1個結點,因此,最少結點數(shù)為k。最多結點個數(shù)借助性質(zhì)1:用求等比級數(shù)前k項和的公式

20+21+22+…+2k-1=2k-110性質(zhì)3

對任何一棵二叉樹,如果其葉結點有n0個,度為2的非葉結點有n2個,則有

n0=n2+1

若設度為1的結點有n1個,總結點數(shù)為n, 總邊數(shù)為e,則根據(jù)二叉樹的定義,

n=n0+n1+n2

e

=2n2+n1=n-1

因此,有2n2+n1=n0+n1+n2-1

n2=n0-1n0=n2+111定義1

滿二叉樹(FullBinaryTree)

定義2

完全二叉樹(CompleteBinaryTree)─若設二叉樹的深度為k,則共有k層。除第k層外,其它各層(1~k-1)的結點數(shù)都達到最大個數(shù),第k層從右向左連續(xù)缺若干結點,這就是完全二叉樹。12理想平衡二叉樹13性質(zhì)4

具有n(n≥0)個結點的完全二叉樹的深度為log2(n+1)

設完全二叉樹的深度為k,則有

2k-1-1<n

≤2k-1

變形2k-1<n+1≤2k

取對數(shù)

k-1<log2(n+1)≤k

log2(n+1)=k上面k-1層結點數(shù)包括第k層的最大結點數(shù)23-124-114性質(zhì)5

如將一棵有n個結點的完全二叉樹自頂向下,同一層自左向右連續(xù)給結點編號1,2,…,n,則有以下關系:

若i=1,則i無雙親若i>1,則i的雙親為i/2若2*i<=n,則i的左子女為

2*i, 若2*i+1<=n,則i的右子女為2*i+1若i為奇數(shù),且i!=1,

則其左兄弟為i-1若

i為偶數(shù),且i!=n,

則其右兄弟為i+11234856791015完全二叉樹一般二叉樹的順序表示的順序表示二叉樹的順序表示1123456789

10

1412346789

12

14248910567312376489125101113161371531極端情形:只有右單支的二叉樹137153117二叉樹結點定義:每個結點有3個數(shù)據(jù)成員,data域存儲結點數(shù)據(jù),leftChild和rightChild分別存放指向左子女和右子女的指針。leftChilddatarightChilddataleftChildrightChild二叉鏈表二叉樹的鏈表表示(二叉鏈表)18leftChilddataparentrightChildparentdataleftChildrightChild三叉鏈表二叉樹的鏈表表示(三叉鏈表)每個結點增加一個指向雙親的指針parent,使得查找雙親也很方便。19二叉樹鏈表表示的示例AAABBBCCCDDDFFFEEErootrootroot二叉樹二叉鏈表三叉鏈表20二叉樹遍歷二叉樹的遍歷就是按某種次序訪問樹中的結點,要求每個結點訪問一次且僅訪問一次。設訪問根結點記作

V

遍歷根的左子樹記作

L

遍歷根的右子樹記作

R則可能的遍歷次序有

前序VLR

鏡像VRL

中序

LVR

鏡像RVL

后序LRV

鏡像RLV21中序遍歷二叉樹算法的框架是:若二叉樹為空,則空操作;否則中序遍歷左子樹(L);訪問根結點(V);中序遍歷右子樹(R)。遍歷結果

a+b*c

-

d

-

e/f中序遍歷(InorderTraversal)--/+*abcdef22前序遍歷二叉樹算法的框架是:若二叉樹為空,則空操作;否則訪問根結點(V);前序遍歷左子樹(L);前序遍歷右子樹(R)。遍歷結果

-+a*b

-

cd/ef前序遍歷(PreorderTraversal)--/+*abcdef23后序遍歷二叉樹算法的框架是:若二叉樹為空,則空操作;否則后序遍歷左子樹(L);后序遍歷右子樹(R);訪問根結點(V)。遍歷結果

abcd

-*+ef/-后序遍歷(PostorderTraversal)--/+*abcdef24由二叉樹的前序序列和中序序列可唯一地確定一棵二叉樹。例,前序序列{ABHFDECKG}

和中序序列{HBDFAEKCG

},構造二叉樹過程如下:HBDFEKCGAEKCGABHDF25前序序列{ABHFDECKG},和中序序列{HBDFAEKCG

}KCGEKCGABHDFEKCGABHFDEABHFDEABHFDCKG26樹的存儲表示樹與森林27子女-兄弟表示也稱為樹的二叉樹表示。結點構造為:firstChild

指向該結點的第一個子女結點。無序樹時,可任意指定一個結點為第一個子女。nextSibling

指向該結點的下一個兄弟。任一結點在存儲時總是有順序的。若想找某結點的所有子女,可先找firstChild,再反復用nextSibling

沿鏈掃描。

datafirstChildnextSibling28樹的子女-

兄弟表示

datafirstChildnextSiblingABCDEFGABCDGFE29樹的遍歷深度優(yōu)先遍歷先根次序遍歷后根次序遍歷廣度優(yōu)先遍歷30樹的先根次序遍歷當樹非空時訪問根結點依次先根遍歷根的各棵子樹31樹的后根次序遍歷當樹非空時依次后根遍歷根的各棵子樹訪問根結點32樹的廣度優(yōu)先(層次次序)遍歷分層次進行33森林廣度優(yōu)先遍歷(層次序遍歷)若森林F

為空,返回; 否則依次遍歷各棵樹的 根結點;依次遍歷各棵樹根 結點的所有子女;依次遍歷這些子女 結點的子女結點;34完全二叉樹順序表示

Ki≤K2i+1&&

Ki≤K2i+2完全二叉樹順序表示Ki≥K2i+1&&

Ki≥K2i+2090987877878454565653131532323531717堆的定義35堆的元素下標計算由于堆存儲在下標從0開始計數(shù)的一維數(shù)組中,因此在堆中給定下標為i

的結點時如果

i=0,結點i

是根結點,無雙親;否則結點i

的父結點為結點(i-1)/2);如果2i+1>n-1,則結點i

無左子女;否則結點i

的左子女為結點2i+1;如果2i+2>n-1,則結點i無右子女;否則結點i的右子女為結點

2i+2。36最小堆調(diào)整算法首先找到最后一個結點的父結點,設其為k依次對i=k,i=k-1,….,i=0進行shiftdown下滑調(diào)整算法,操作范圍包括所有隸屬于i結點的子孫結點下滑時依據(jù)子女結點的關鍵碼值確定方向(沿關鍵碼值小的一側子女結點下滑)37自下向上逐步調(diào)整為最小堆currentPos=i=3currentPos=i=25353171778780923456587i0923456587i將一組用數(shù)組存放的任意數(shù)據(jù)調(diào)整成堆38currentPos=i=15353171778780923456587i0923456587i39currentPos=i=05353171778780923456587i0923456587i09405353171778780923456587i0923456587i1741

每次插入都加在堆的最后,再自下向上執(zhí)行調(diào)整,使之重新形成堆。最小堆的插入42在堆中插入新元素1153171778780923456587i0923456587j1153j1123i最小堆的向上調(diào)整(shiftup)從下向上和父結點比較435317117878094565870923456587j115323i2317ji44Huffman樹路徑長度(PathLength)

路徑:從樹中一個結點到另一個結點的分支構成兩結點間的路徑兩個結點之間的路徑長度PL

是連接兩結點的路徑上的分支數(shù)451122334455667788PL=0+1+1+2+2+2+2+3=13PL=0+1+1+2+2+3+3+4=1646帶權路徑長度

(WeightedPathLength,WPL)在很多應用問題中為樹的葉結點賦予一個權值,用于表示出現(xiàn)頻度、概率值等。因此,在問題處理中把葉結點定義得不同于非葉結點,把葉結點看成“外結點”,非葉結點看成“內(nèi)結點”。這樣的二叉樹稱為擴充二叉樹。47若一棵擴充二叉樹有n個外結點,第i個外結點的權值為wi,它到根的路徑長度為li,則該外結點到根的帶權路徑長度為wi*li。擴充二叉樹的帶權路徑長度定義為樹的各外結點到根的帶權路徑長度之和。對于同樣一組權值,如果放在外結點上,組織方式不同,帶權路徑長度也不同。48具有不同帶權路徑長度的擴充二叉樹WPL=2*2+WPL=2*1+WPL=7*1+4*2+5*2+4*2+5*3+5*2+2*3+7*2=367*3=4

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論