




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
Matlab最短路徑算法(精)2主要內(nèi)容Floyd算法Dijkstra算法兩個例子的求解引例2:最廉價航費表的制定引例1:最短運輸路線問題3如圖的交通網(wǎng)絡(luò),每條弧上的數(shù)字代表車輛在該路段行駛所需的時間,有向邊表示單行道,無向邊表示可雙向行駛。若有一批貨物要從1號頂點運往11號頂點,問運貨車應(yīng)沿哪條線路行駛,才能最快地到達(dá)目的地?
引例1:最短運輸路線問題
102374116598135122106158879932274
某公司在六個城市C1,C2,C3,C4,C5,C6都有分公司,公司成員經(jīng)常往來于它們之間,已知從Ci到Cj的直達(dá)航班票價由下述矩陣的第i行,第j列元素給出(
表示無直達(dá)航班),該公司想算出一張任意兩個城市之間的最廉價路線航費表。
引例2:最廉價航費表的制定5最短路徑問題定義:設(shè)P(u,v)是加權(quán)圖G中從u到v的路徑,則該路徑上的邊權(quán)之和稱為該路徑的權(quán),記為w(P).從u到v的路徑中權(quán)最小者P*(u,v)稱為u到v的最短路徑.102374116598135122106158879932276最短路徑算法Dijkstra算法使用范圍:尋求從一固定頂點到其余各點的最短路徑;有向圖、無向圖和混合圖;權(quán)非負(fù).算法思路:采用標(biāo)號作業(yè)法,每次迭代產(chǎn)生一個永久標(biāo)號,從而生長一顆以v0為根的最短路樹,在這顆樹上每個頂點與根節(jié)點之間的路徑皆為最短路徑.102374116598135122106158879932277Dijkstra算法——算法步驟S:具有永久標(biāo)號的頂點集;l(v):v的標(biāo)記;f(v):v的父頂點,用以確定最短路徑;
輸入加權(quán)圖的帶權(quán)鄰接矩陣w=[w(vi,vj)]nxm.初始化令l(v0)=0,S=;vv0,l(v)=;更新l(v),f(v)
尋找不在S中的頂點u,使l(u)為最小.把u加入到S中,然后對所有不在S中的頂點v,如l(v)>l(u)+w(u,v),則更新l(v),f(v),即l(v)l(u)+w(u,v),f(v)u;重復(fù)步驟2),直到所有頂點都在S中為止.8MATLAB程序(Dijkstra算法)function[min,path]=dijkstra(w,start,terminal)n=size(w,1);label(start)=0;f(start)=start;fori=1:nifi~=startlabel(i)=inf;end,ends(1)=start;u=start;whilelength(s)<nfori=1:nins=0;forj=1:length(s)ifi==s(j)ins=1;end,endifins==0v=i;iflabel(v)>(label(u)+w(u,v))label(v)=(label(u)+w(u,v));f(v)=u;end,end,endv1=0;k=inf;fori=1:nins=0;forj=1:length(s)ifi==s(j)ins=1;end,endifins==0v=i;ifk>label(v)k=label(v);v1=v;end,end,ends(length(s)+1)=v1;u=v1;endmin=label(terminal);path(1)=terminal;i=1;whilepath(i)~=startpath(i+1)=f(path(i));i=i+1;endpath(i)=start;L=length(path);path=path(L:-1:1);①②③9最短路徑算法Dijkstra算法程序的使用說明:調(diào)用格式為
[min,path]=dijkstra(w,start,terminal),
其中輸入變量w為所求圖的帶權(quán)鄰接矩陣,start,terminal分別為路徑的起點和終點的號碼。返回start到terminal的最短路徑path及其長度min.注意:頂點的編號從1開始連續(xù)編號。10最短路徑算法Floyd算法使用范圍:求每對頂點的最短路徑;有向圖、無向圖和混合圖;算法思想:
直接在圖的帶權(quán)鄰接矩陣中用插入頂點的方法依次遞推地構(gòu)造出n個矩陣D(1),D(2),…,D(n),D(n)是圖的距離矩陣,同時引入一個后繼點矩陣記錄兩點間的最短路徑.1023741165981351221061588799322711Floyd算法——算法步驟d(i,j):i到j(luò)的距離;path(i,j):i到j(luò)的路徑上i的后繼點;
輸入帶權(quán)鄰接矩陣a(i,j).1)賦初值對所有i,j,d(i,j)a(i,j),path(i,j)j,k=l.2)更新d(i,j),path(i,j)
對所有i,j,
若d(i,k)+d(k,j)<d(i,j),則
d(i,j)d(i,k)+d(k,j),path(i,j)path(i,k),kk+13)重復(fù)2)直到k=n+112MATLAB程序(Floyd算法)function[D,path,min1,path1]=floyd(a,start,terminal)D=a;n=size(D,1);path=zeros(n,n);fori=1:nforj=1:nifD(i,j)~=infpath(i,j)=j;end,end,endfork=1:nfori=1:nforj=1:nifD(i,k)+D(k,j)<D(i,j)D(i,j)=D(i,k)+D(k,j);path(i,j)=path(i,k);end,end,end,endifnargin==3min1=D(start,terminal);m(1)=start;i=1;path1=[];whilepath(m(i),terminal)~=terminalk=i+1;m(k)=path(m(i),terminal);i=i+1;endm(i+1)=terminal;path1=m;end13最短路徑算法Floyd算法程序的使用說明:1.[D,path]=floyd(a),返回矩陣D,path。其中a是所求圖的帶權(quán)鄰接矩陣,D(i,j)表示i到j(luò)的最短距離;path(i,j)表示i與j之間的最短路徑上頂點i的后繼點.2.[D,path,min1,path1]=floyd(a,i,j)返回矩陣D,path;并返回i與j之間的最短距離min1和最短路徑path1.14edge=[2,3,1,3,3,5,4,4,1,7,6,6,5,5,11,1,8,6,9,10,8,9,9,10;...3,4,2,7,5,3,5,11,7,6,7,5,6,11,5,8,1,9,5,11,9,8,10,9;...3,5,8,5,6,6,1,12,7,9,9,2,2,10,10,8,8,3,7,2,9,9,2,2];n=11;weight=inf*ones(n,n);fori=1:nweight(i,i)=0;endfori=1:size(edge,2)weight(edge(1,i),edge(2,i))=edge(3,i);end[dis,path]=dijkstra(weight,1,11)引例1的Matlab求解1023741165981351221061588799322715運行上頁程序輸出:dis=21path=1891011
因此頂點1到頂點11
溫馨提示
- 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河北省安全員《A證》考試題庫及答案
- 二零二五年度智能制造入股合同協(xié)議書
- 2025年度農(nóng)業(yè)科技企業(yè)員工借調(diào)與農(nóng)業(yè)技術(shù)推廣合同
- 2025年度個體工商戶合伙協(xié)議范文與投資融資及財務(wù)規(guī)劃協(xié)議
- 2025年度征收城市老舊危房房屋拆遷補(bǔ)償協(xié)議
- 2025年度人事專員勞動合同(附員工培訓(xùn)服務(wù)內(nèi)容)
- 2025年度文化產(chǎn)業(yè)發(fā)展勞動合同法規(guī)范與創(chuàng)意人才合同
- 2025年度個人租賃市場租賃合同電子簽名合同
- 2025年度健康養(yǎng)生館店鋪承包合作協(xié)議
- 2025年度太陽能光伏發(fā)電站機(jī)電安裝服務(wù)協(xié)議
- 大學(xué)轉(zhuǎn)專業(yè)高等數(shù)學(xué)試卷
- DBJ51-T 198-2022 四川省既有民用建筑結(jié)構(gòu)安全隱患排查技術(shù)標(biāo)準(zhǔn)
- 公司廠區(qū)保潔培訓(xùn)
- 江蘇省招標(biāo)中心有限公司招聘筆試沖刺題2025
- 2024年防盜門銷售合同范本
- 支付令申請書(2025版)
- 《干細(xì)胞及其應(yīng)用》課件
- 課題申報書:生成式人工智能提升中小學(xué)教師數(shù)字素養(yǎng)的路徑探究
- 麻醉護(hù)士的 工作職責(zé)
- 2025年中考語文一輪復(fù)習(xí):九年級下冊知識點梳理
- 旅游健康與保健知識
評論
0/150
提交評論