版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
算法設(shè)計與分析
AlgorithmsDesignandAnalysis
趙廷剛蘭州城市學(xué)院數(shù)學(xué)學(xué)院2013.3本章內(nèi)容4.1引言4.2堆(heaps)4.2.1堆上的運(yùn)算4.2.2創(chuàng)建堆4.2.3堆排序4.2.4最小堆和最大堆4.3不相交集數(shù)據(jù)結(jié)構(gòu)(disjointsetsdatastructures)4.3.1按秩合并措施4.3.2路徑壓縮4.3.3UNION-FIND算法4.3.4UNION-FIND算法分析
數(shù)據(jù)結(jié)構(gòu)(datastructure)是計算機(jī)中存儲、組織數(shù)據(jù)的方式。通常情況下,精心選擇的數(shù)據(jù)結(jié)構(gòu)可以帶來最優(yōu)效率的算法。
4.1引言常見數(shù)據(jù)結(jié)構(gòu):數(shù)組(array)、列表(list)、堆棧(stack)、隊列(queue)、鏈表(linkedlist)、樹(tree)、圖(graph)、堆(heap)、散列(hash)4.2堆(heaps)在許多算法中,需要支持兩種運(yùn)算的數(shù)據(jù)結(jié)構(gòu):插入元素和尋找最大值元素。支持這兩種運(yùn)算的數(shù)據(jù)結(jié)構(gòu)稱為優(yōu)先隊列。如果使用普通隊列,那么尋找最大元素需要搜索整個隊列,開銷比較大;如果采用排序數(shù)組,那么插入運(yùn)算就需要移動很多元素,開銷也會較大。優(yōu)先隊列的有效實(shí)現(xiàn)是使用“堆”的簡單數(shù)據(jù)結(jié)構(gòu)。一個(二叉)堆是一個幾乎完全的二叉樹,它的每個節(jié)點(diǎn)都滿足堆的特性:如果v和p(v)分別是節(jié)點(diǎn)和它的父節(jié)點(diǎn),那么存儲在p(v)中的數(shù)據(jù)項鍵值不小于存儲在v中的數(shù)據(jù)項鍵值。定義4.1堆數(shù)據(jù)結(jié)構(gòu)支持下面的運(yùn)算:delete-max[H]:從堆H中刪除最大鍵值的數(shù)據(jù)項并將數(shù)據(jù)項返回。insert[H,x]:插入項x到堆H中。delete[H,i]:從堆H中刪除第i項。makeheap[A]:將數(shù)組A轉(zhuǎn)換成堆。堆的例子/view/4147d863caaedd3383c4d3c6.html注意:如果堆中的節(jié)點(diǎn)有右子節(jié)點(diǎn),則它一定也有左子節(jié)點(diǎn)。堆可以看做是二叉樹,而它實(shí)質(zhì)上是一個數(shù)組H[1…n]。它有如下性質(zhì):/p-240830965233.html4.2.1堆上的運(yùn)算----sift-up假設(shè)對某個i>1,H[i]變成了鍵值大于它的父節(jié)點(diǎn)鍵值的元素,這樣就違反了堆性質(zhì),因此該數(shù)據(jù)結(jié)構(gòu)就不再是堆了,如果要修復(fù)它成為堆,就用sift-up的運(yùn)算.算法描述:Sift-up運(yùn)算沿著從H[i]到根節(jié)點(diǎn)的唯一一條路徑,把H[i]移到適合它的位置上。在沿著路徑的每一步上,都將H[i]鍵值與它的父節(jié)點(diǎn)的鍵值相比較。4.2.1堆上的運(yùn)算----sift-down假設(shè)對i≤floor(i/2),存儲在H[i]中元素的鍵值變成小于H[2i]和H[2i+1]中的最大值,這樣也違反了堆性質(zhì),因此該數(shù)據(jù)結(jié)構(gòu)就不再是堆了,如果要修復(fù)它成為堆,就用sift-down的運(yùn)算.算法描述:Sift-down運(yùn)算使H[i]“滲”到二叉樹中適合它的位置上,沿著路徑的每一步上,都將H[i]鍵值與存儲在它的子節(jié)點(diǎn)(如果有)的兩個(可能是一個)鍵值里最大的那個相比較。4.2.1堆上的運(yùn)算----插入(insert)插入:為了把元素x插入到堆H中,先將堆大小加1,然后將x添加到H的末尾,再根據(jù)需要,將x上移,直到滿足堆性質(zhì).4.2.1堆上的運(yùn)算----刪除(delete)刪除:要從大小為n的堆H中刪除元素H[i],可先用H[n]替換H[i],然后將堆棧大小減1,如果需要的話,根據(jù)H[i]的鍵值與存儲在它的父節(jié)點(diǎn)和子節(jié)點(diǎn)中元素鍵值的大小,對H[i]做sift-up或sift-down運(yùn)算,直到滿足堆性質(zhì).4.2.1堆上的運(yùn)算----刪除最大值(delete-max)刪除最大值:要從大小為n的堆H中刪除元素H[i],可先用H[n]替換H[i],然后將堆棧大小減1,如果需要的話,根據(jù)H[i]的鍵值與存儲在它的父節(jié)點(diǎn)和子節(jié)點(diǎn)中元素鍵值的大小,對H[i]做sift-up或sift-down運(yùn)算,直到滿足堆性質(zhì).4.2.2堆上的運(yùn)算----創(chuàng)建堆(makeheap)創(chuàng)建堆:給出一個有n個元素的數(shù)組A[1…n],將該數(shù)組變成一個幾乎完全的二叉樹,并把這個二叉樹轉(zhuǎn)換成一個堆。從最后一個節(jié)點(diǎn)開始(編碼為n的節(jié)點(diǎn))到根節(jié)點(diǎn)(編碼為1的節(jié)點(diǎn)),逐個掃描,根據(jù)需要每次將當(dāng)前節(jié)點(diǎn)為根的子樹轉(zhuǎn)換為堆。例4.34.2.3堆排序算法描述:給出數(shù)組A[1…n],首先將它轉(zhuǎn)換為堆,由于最大值在A[1]中,所以將A[1]和A[n]互換,這樣A[n]中存放了最大值,接下來考慮數(shù)組A[1…n-1],它可能不是堆,利用sift-down運(yùn)算將A[1…n-1]轉(zhuǎn)換成堆,再將A[1]和A[n-1]互換,如此下去,直到堆的大小變?yōu)?,即可。4.3不相交集數(shù)據(jù)結(jié)構(gòu)假設(shè)有一個包含n個元素的集合S,它被分成不相交的一些子集,每個子集用其中的一個元素做名字或代表。例如:S={1,2,……,11},子集合為{1,7,10,11},{2,3,5,6},{4,8},{9}這4個子集合被依次命名為1,3,8,9.FIND(x):返回包含x的子集合的名字。UNION(x,y):將包含x的子集合與包含y的子集合合并,得到的并集的名字取原來兩個子集合的名字之一。根樹表示法:用根樹表示每個子集合,子集合中的元素存儲在節(jié)點(diǎn)中,樹中除根節(jié)點(diǎn)外的每一個元素x都有一個指向父節(jié)點(diǎn)p(x)的指針.根有一個空指針,用作集合的名字或代表。這些根樹在一起組成一個森林。對于任意元素x,用root(x)表示包含x的樹的根。那么,F(xiàn)IND(x)總是返回root(x)。由于合并運(yùn)算必須有兩棵樹的根作為它的參數(shù),我們將假定對于任意兩個元素x和y,UNION(x,y)實(shí)際上是表示UNION(root(x),root(y)).在進(jìn)行FIND(x)運(yùn)算時,只是沿著從x開始直到根節(jié)點(diǎn)的路徑,然后返回root(x)。在進(jìn)行UNION(x,y)運(yùn)算時,令root(x)的鏈接指向root(y),也就是說,如果root(x)是u,root(y)是v,就令v是u的父節(jié)點(diǎn).一個極端例子:假設(shè)集合S={1,2,…,n},它的子集合為:{1},{2},…,{n}.執(zhí)行n-1個合并運(yùn)算:UNION{1,2},UNION{2,3},…,UNION{n-1,n}之后的結(jié)果見圖4.6(a),這是一個高度為n-1的樹。如果接下來要執(zhí)行尋找運(yùn)算:FIND(1),FIND(2),…,FIND(n),則n次尋找的總代價為:這是很耗費(fèi)時間的,為了克服這個弊端,采用:按秩合并措施和路徑壓縮措施。4.3.1按秩合并措施為了限制每棵樹的高度,采用按秩合并措施:給每個節(jié)點(diǎn)存儲一個非負(fù)數(shù)作為該節(jié)點(diǎn)的秩,記為rank,節(jié)點(diǎn)的秩基本上就是它的高度。設(shè)x和y是當(dāng)前森林中兩棵不同的根樹的根,初始狀態(tài)時,每個節(jié)點(diǎn)的秩是0,在執(zhí)行運(yùn)算UNION(x,y)時,比較rank(x)和rank(y),如果rank(x)<rank(y),就使y為x的父節(jié)點(diǎn);如果rank(x)>rank(y),就使x為y的父節(jié)點(diǎn);如果rank(x)=rank(y),就使y為x的父節(jié)點(diǎn),并rank(y)加1.那個極端例子:按照上述規(guī)則之后的結(jié)果見圖4.6(b),這是一個高度為1的樹。如果接下來要執(zhí)行尋找運(yùn)算:FIND(1),FIND(2),…,FIND(n),則n次尋找的總代價為:n
溫馨提示
- 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年重慶幼兒師范高等專科學(xué)校單招職業(yè)技能考試題庫帶答案解析
- 紅原縣氣候特征
- 服裝公司網(wǎng)絡(luò)設(shè)備采購辦法
- 化工公司培訓(xùn)管理執(zhí)行細(xì)則
- 2025年昭通衛(wèi)生職業(yè)學(xué)院馬克思主義基本原理概論期末考試模擬題附答案解析(奪冠)
- 2025年懷仁縣幼兒園教師招教考試備考題庫及答案解析(必刷)
- 某服裝公司熨燙設(shè)備使用規(guī)范細(xì)則
- 2025年阿勒泰職業(yè)技術(shù)學(xué)院單招職業(yè)技能測試題庫帶答案解析
- 2025年鄭州汽車工程職業(yè)學(xué)院單招職業(yè)適應(yīng)性考試題庫附答案解析
- 2025年蘇州健雄職業(yè)技術(shù)學(xué)院單招職業(yè)技能考試模擬測試卷帶答案解析
- 2025北京市體育局所屬事業(yè)單位招聘100人筆試參考題庫及答案解析
- 膿毒癥診斷與治療臨床規(guī)范指南(2025年版)
- 國有企業(yè)財務(wù)管理制度
- 安裝銅排施工方案(3篇)
- 河南省鄭州市第六十二中學(xué)2025-2026學(xué)年九年級上學(xué)期第二次月考語文試題(含答案)
- 物流倉儲管理表格庫存狀態(tài)與操作指導(dǎo)模板
- 日本風(fēng)格家居空間設(shè)計解析
- 2025年湖南銀行筆試題庫及答案
- 商鋪應(yīng)急預(yù)案范本(3篇)
- 2025年湖南省考考試真題及答案
- 山西省太原市2025-2026學(xué)年數(shù)學(xué)高一第一學(xué)期期末檢測試題含解析
評論
0/150
提交評論