版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
討論課題:最小生成樹的求解方法與分析點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本目錄背景知識(shí)組內(nèi)成員分工介紹最小生成樹的求解方法與分析010203點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本組內(nèi)成員及分工介紹:
組長(zhǎng)劉先喆:編寫最小生成樹求解方法、回答問題
組員陳靜:匯報(bào)演講、制作PPT
組員何安琪:制作PPT、分析算法、探索其他解決方法
組員韓佳文:撰寫報(bào)告提問問題
組員李昕翼:撰寫報(bào)告提問問題最小連接問題交通網(wǎng)絡(luò)中,常常關(guān)注能把所有站點(diǎn)連接起來的生成樹,使得該生成樹各邊權(quán)值之和為最小。例如:假設(shè)要在某地建造5個(gè)工廠,擬修筑道路連接這5處。經(jīng)勘探,其道路可按無向邊鋪設(shè)?,F(xiàn)在每條邊的長(zhǎng)度已經(jīng)測(cè)出并標(biāo)記在對(duì)應(yīng)邊上,如果我們要求鋪設(shè)的道路總長(zhǎng)度最短,如何鋪設(shè)?背景知識(shí)最小生成樹:在連通邊賦權(quán)圖G中求一棵總權(quán)值最小的生成樹。該生成樹稱為最小生成樹或最小代價(jià)樹。構(gòu)造最小生成樹的思想構(gòu)造最小生成樹可以有多種算法。其中多數(shù)算法利用了最小生成樹的一種簡(jiǎn)稱為MST的性質(zhì):假設(shè)N=(V,{E})是一個(gè)連通網(wǎng)(v代表頂點(diǎn)集,E代表邊集),U是頂點(diǎn)集V的一個(gè)非空子集。若(u,v)是一條具有最小權(quán)值的邊,其中u∈U,v∈V-U,則必存在一棵包含邊(u,v)的最小生成樹。點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本普里姆算法克魯斯卡爾構(gòu)造算法最小生成樹普里姆算法從連通網(wǎng)N={V,E}中的某一頂點(diǎn)U0出發(fā),選擇與它關(guān)聯(lián)的具有最小權(quán)值的邊(U0,v),將其頂點(diǎn)加入到生成樹的頂點(diǎn)集合U中。以后每一步從一個(gè)頂點(diǎn)在U中,而另一個(gè)頂點(diǎn)不在U中的各條邊中選擇權(quán)值最小的邊(u,v),把它的頂點(diǎn)加入到集合U中。如此繼續(xù)下去,直到網(wǎng)中的所有頂點(diǎn)都加入到生成樹頂點(diǎn)集合U中為止普里姆算法利用該圖按普里姆算法構(gòu)造一棵最小生成樹V3V2V1V4V5V65515666423V1V2V5V4V6V36513246556
iclosedgev2v3v4v5v6UV-Ukadjvexlowcost61V15V3V1V1V1615{V1}{V2,V3,V4,V5,V6}v3V1V2V5V4V6V36513246556
iclosedgev2v3v4v5v6UV-Ukadjvexlowcost51V15V3V3V1505{V1,V3}{V2,V4,V5,V6}v6V36V3464V3V6V1V2V5V4V6V36513246556
iclosedgev2v3v4v5v6UV-Ukadjvexlowcost004625V6V465v4V62V3V3{V1,V3,V6}{V2,V4,V5}V1V2V5V4V6V36513246556
iclosedgev2v3v4v5v6UV-Ukadjvexlowcost0002V4V3556V36{V1,V3,V6,V4}{V2,V5}v2V2V1V2V5V4V6V36513246556
iclosedgev2v3v4v5v6UV-Ukadjvexlowcost00005V2{V1,V3,V6,V4,V2}{V5}v53V23V5V1V2V5V4V6V36513246556
iclosedgev2v3v4v5v6UV-Ukadjvexlowcost000003V5{V1,V3,V6,V4,V2,v5}{}普里姆核心算法//用普里姆算法從第u個(gè)頂點(diǎn)出發(fā)構(gòu)造網(wǎng)G的最小生成樹T,輸出T的各條邊voidMiniSpanTree_PRIM(MGraphG,VertexTypeu){ inti,j,k; Closedgeclosedge; k=LocateVex(G,u); for(j=0;j<G.vexnum;++j)//輔助數(shù)組初始化 { if(j!=k) { strcpy(closedge[j].adjvex,u); closedge[j].lowcost=G.arcs[k][j].adj; } }..\..\普里姆算法\普里姆.cpp
closedge[k].lowcost=0;//初始時(shí),U={u} printf("最小代價(jià)生成樹的各條邊為:\n"); for(i=1;i<G.vexnum;++i) {//選擇其余G.vexnum-1個(gè)頂點(diǎn) k=MiniNum(closedge,G);//求出T的下一個(gè)結(jié)點(diǎn):第K頂點(diǎn) printf("(%s-%s)%d\n",closedge[k].adjvex,G.vexs[k],closedge[k].lowcost);//輸出生成樹的邊 closedge[k].lowcost=0;//第K頂點(diǎn)并入U(xiǎn)集 for(j=0;j<G.vexnum;++j) if(G.arcs[k][j].adj<closedge[j].lowcost) { //新頂點(diǎn)并入U(xiǎn)集后重新選擇最小邊 strcpy(closedge[j].adjvex,G.vexs[k]); closedge[j].lowcost=G.arcs[k][j].adj; } }}普里姆算法分析假設(shè)網(wǎng)中有n個(gè)頂點(diǎn),則第一個(gè)進(jìn)行初始化的循環(huán)語句的頻度為n,第二個(gè)循環(huán)語句的頻度為n-1;其中有兩個(gè)內(nèi)循環(huán):其一是在closedge[v].lowcost中求最小值,其頻度為n-1;其二是重新選擇具有最小代價(jià)的邊,其頻度為n。由此,普里姆算法的時(shí)間復(fù)雜度為O(n2),與網(wǎng)中的邊數(shù)無關(guān),因此適用于求邊稠密的網(wǎng)的最小生成樹??唆斔箍査惴唆斔箍査惴◤牧硪煌緩角缶W(wǎng)的最小生成樹。假設(shè)連通網(wǎng)N=(V,{E}),則令最小生成樹的初始狀態(tài)為只有n個(gè)頂點(diǎn)而無邊的非連通圖T=(V,{}),圖中每個(gè)頂點(diǎn)自成一個(gè)連通分量。在E中選擇代價(jià)最小的邊,若該邊依附的頂點(diǎn)落在T中不同的連通分量上,則將此邊加入到T中,否則舍去此邊而選擇下一條代價(jià)最小的邊。以此類推,直至T中所有頂點(diǎn)都在同一連通分量上為止??唆斔箍査惴ɡ迷搱D按克魯斯卡爾算法構(gòu)造一棵最小生成樹V3V2V1V4V5V65515666423各邊權(quán)值的堆排
12345678910edgecost6155356426adjvexv1,v2v1,v3v1,v4v3,v4v2,v5v2,v3v3,v5v3,v6v4,v6v5,v66156325564
12345678910edgecost1234555666adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v3v1,v4v3,v5v5,v6v1,v2利用堆排序后結(jié)果:V1V3V2V5V6V41636625554
123456edgecost123455adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v31V1V3V2V5V6V41636625554
123456edgecost123455adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v32V1V3V2V5V6V41636625554
123456edgecost123455adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v33V1V3V2V5V6V41636625554
123456edgecost123455adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v34V1V3V2V5V6V41636625554
123456edgecost123455adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v35V1V3V2V5V6V41636625554
123456edgecost123455adjvexv1,v3v4,v6v2,v5v3,v6v3,v4v2,v35克魯斯卡爾核心算法for(i=0;i<G.vexnum;i++)//各頂點(diǎn)集初始化 flag[i]=i; for(i=G.arcnum,count=1;count<G.vexnum;i--) { j=G.arcs[i].v1;k=G.arcs[i].v2; if(flag[j]!=flag[k])//兩個(gè)點(diǎn)屬于不同集合 { printf("(%s-%s)%d\n",G.vexs[j],G.vexs[k],G.arcs[i].value); count++; for(l=0;l<G.vexnum;l++) if(flag[l]==flag[k])//將點(diǎn)k所在集合的點(diǎn)并入j所在集合 flag[l]=flag[j]; } }
..\..\克魯斯卡爾算法\最小生成樹.cpp克魯斯卡爾算法分析該算法至多對(duì)e條邊各掃描一次,則每次選擇最小代價(jià)的邊僅需O(loge)的時(shí)間(第一次需O(e))。又生成樹T的每個(gè)連通分量可以看成是一個(gè)等價(jià)類,則構(gòu)造T加入新的邊的過程類似于求等價(jià)類的過程,構(gòu)造T的過程僅需O(eloge)的時(shí)間,由此,克魯斯卡爾算法的時(shí)間復(fù)雜度為O(eloge)。點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本點(diǎn)擊添加文本Solin算法Rosenstiehl和管梅谷算法Dijkstra算法最小生成樹的其他求解方法Solin算法
此算法的基本思路是:將求連通帶權(quán)圖的最小生成樹的過程分為若干階段,每一階段選取若干條邊。具體步驟如下:(1)將每個(gè)頂點(diǎn)視為一棵樹,圖中所有頂點(diǎn)視為一個(gè)森林;(2)為每棵樹選取一條邊,它是該樹與其他樹相連的所有邊中權(quán)值最小的
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東科貿(mào)職業(yè)學(xué)院《科學(xué)中醫(yī)筋膜學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東江門中醫(yī)藥職業(yè)學(xué)院《森林生態(tài)學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東技術(shù)師范大學(xué)《環(huán)境信息系統(tǒng)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東環(huán)境保護(hù)工程職業(yè)學(xué)院《生物信息分析》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東工商職業(yè)技術(shù)大學(xué)《工業(yè)生物過程導(dǎo)論》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東第二師范學(xué)院《求職訓(xùn)練》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東財(cái)貿(mào)職業(yè)學(xué)院《舞蹈身體語》2023-2024學(xué)年第一學(xué)期期末試卷
- 小班結(jié)核病安全教育課件
- 光纖通信概論教學(xué)課件
- 廣東碧桂園職業(yè)學(xué)院《基坑工程》2023-2024學(xué)年第一學(xué)期期末試卷
- 度三年級(jí)語文上冊(cè)期末試卷(圖片版含答案)
- 農(nóng)林牧漁類專業(yè)綜合訓(xùn)練卷 第20卷 (原卷版)
- 2024年中國輔酶Q10膠囊行業(yè)投資分析、市場(chǎng)運(yùn)行態(tài)勢(shì)、未來前景預(yù)測(cè)報(bào)告
- FANUC機(jī)器人培訓(xùn)教程(完成版)
- 玉溪大紅山鐵礦二期北采區(qū)采礦施工組織設(shè)計(jì)
- 中醫(yī)診療技術(shù)操作規(guī)程
- 樂理知識(shí)考試題庫130題(含答案)
- 2024年外研版九年級(jí)英語上冊(cè)知識(shí)點(diǎn)總結(jié)
- 2024新教科版四年級(jí)上冊(cè)科學(xué)知識(shí)點(diǎn)總結(jié)精簡(jiǎn)版
- (完整)北京版小學(xué)英語1至6年級(jí)詞匯(帶音標(biāo))
- 《朝花夕拾》閱讀推進(jìn)課 教學(xué)設(shè)計(jì)-2023-2024學(xué)年統(tǒng)編版語文七年級(jí)下冊(cè)
評(píng)論
0/150
提交評(píng)論