




已閱讀5頁,還剩7頁未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Dijkstra算法Dijkstra算法是典型最短路算法,用于計(jì)算一個(gè)節(jié)點(diǎn)到其他所有節(jié)點(diǎn)的最短路徑。主要特點(diǎn)是以起始點(diǎn)為中心向外層層擴(kuò)展,直到擴(kuò)展到終點(diǎn)為止。Dijkstra算法能得出最短路徑的最優(yōu)解,但由于它遍歷計(jì)算的節(jié)點(diǎn)很多,所以效率低。Dijkstra算法是很有代表性的最短路算法,在很多專業(yè)課程中都作為基本內(nèi)容有詳細(xì)的介紹,如數(shù)據(jù)結(jié)構(gòu),圖論,運(yùn)籌學(xué)等等。Dijkstra一般的表述通常有兩種方式,一種用永久和臨時(shí)標(biāo)號(hào)方式,一種是用OPEN,CLOSE表方式,Drew為了和下面要介紹的A*算法和D*算法表述一致,這里均采用OPEN,CLOSE表的方式。其采用的是貪心法的算法策略大概過程:創(chuàng)建兩個(gè)表,OPEN,CLOSE。OPEN表保存所有已生成而未考察的節(jié)點(diǎn),CLOSED表中記錄已訪問過的節(jié)點(diǎn)。1訪問路網(wǎng)中距離起始點(diǎn)最近且沒有被檢查過的點(diǎn),把這個(gè)點(diǎn)放入OPEN組中等待檢查。2從OPEN表中找出距起始點(diǎn)最近的點(diǎn),找出這個(gè)點(diǎn)的所有子節(jié)點(diǎn),把這個(gè)點(diǎn)放到CLOSE表中。3遍歷考察這個(gè)點(diǎn)的子節(jié)點(diǎn)。求出這些子節(jié)點(diǎn)距起始點(diǎn)的距離值,放子節(jié)點(diǎn)到OPEN表中。4重復(fù)第2和第3步,直到OPEN表為空,或找到目標(biāo)點(diǎn)。編輯本段算法實(shí)現(xiàn)#include#defineMaxNum765432100usingnamespacestd;ifstreamfin(Dijkstra.in);ofstreamfout(Dijkstra.out);intMap501501;boolis_arrived501;intDist501,From501,Stack501;intp,q,k,Path,Source,Vertex,Temp,SetCard;intFindMin()intp,Temp=0,Minm=MaxNum;for(p=1;p=Vertex;p+)if(DistpSourceVertex;for(p=1;p=Vertex;p+)for(q=1;qMappq;if(Mappq=0)Mappq=MaxNum;for(p=1;p=Vertex;p+)Distp=MapSourcep;if(Distp!=MaxNum)Fromp=Source;elseFromp=p;is_arrivedSource=true;SetCard=1;doTemp=FindMin();if(Temp!=0)SetCard=SetCard+1;is_arrivedTemp=true;for(p=1;pDistTemp+MapTempp)&(!is_arrivedp)Distp=DistTemp+MapTempp;Fromp=Temp;elsebreak;while(SetCard!=Vertex);for(p=1;p=Vertex;p+)if(p!=Source)fout=n;foutSource:SourcenTarget:pn;if(Distp=MaxNum)foutDistance:Infinityn;foutPath:NoWay!;elsefoutDistance:Distpn;k=1;Path=p;while(FromPath!=Path)Stackk=Path;Path=FromPath;k=k+1;foutPath:=1;q-)foutStackq;fout1=Source:2Target:3Distance:25Path:2-3=Source:2Target:4Distance:50Path:2-1-4=Source:2Target:5Distance:50Path:2-3-5=Source:2Target:6Distance:60Path:2-3-5-6=Source:2Target:7Distance:InfinityPath:NoWay!=示例程序及相關(guān)子程序:voidDijkstra(intn,intDistance,intiPath)intMinDis,u;inti,j;/從鄰接矩陣復(fù)制第n個(gè)頂點(diǎn)可以走出的路線,就是復(fù)制第n行到Distancefor(i=0;iVerNum;i+)Distance=Arcn,i;Visited=0;/第n個(gè)頂點(diǎn)被訪問,因?yàn)榈趎個(gè)頂點(diǎn)是開始點(diǎn)Visitedn=1;/找到該頂點(diǎn)能到其他頂點(diǎn)的路線、并且不是開始的頂點(diǎn)n、以前也沒走過。/相當(dāng)于尋找u點(diǎn),這個(gè)點(diǎn)不是開始點(diǎn)nfor(i=0;iVerNum;i+)u=0;MinDis=No;for(j=0;jVerNum;j+)if(Visitedj=0&(DistancejMinDis)MinDis=Distancej;u=j;/如范例P1871圖G6,Distance=No,No,10,No,30,100,第一次找就是V2,所以u(píng)=2/找完了,MinDis等于不連接,則返回。這種情況類似V5。if(MinDis=No)return;/確立第u個(gè)頂點(diǎn)將被使用,相當(dāng)于Arcv,u+Arcu,w中的第u頂點(diǎn)。Visitedu=1;/尋找第u個(gè)頂點(diǎn)到其他所有頂點(diǎn)的最小路,實(shí)際就是找Arcu,j、j取值在0,VerNum。/如果有Arci,u+Arcu,jArci,j,則Arci,j=Arci,u+Arcu,jArci,j/實(shí)際中,因?yàn)镈istance是要的結(jié)果,對(duì)于起始點(diǎn)確定的情況下,就是:/如果(Distanceu+Arcu,j)=Distancej則:/Distancej=Distanceu+Arcu,j;/而iPath保存了u點(diǎn)的編號(hào);/同理:對(duì)新找出的路線,要設(shè)置Visitedj=0,以后再找其他路,這個(gè)路可能別利用到。例如V3for(j=0;jVerNum;j+)if(Visitedj=0&Arcu,jNo&u!=j)if(Distanceu+Arcu,j)=Distancej)Distancej=Distanceu+Arcu,j;Visitedj=0;iPathj=u;/輔助函數(shù)voidPrim()inti,m,n=0;for(i=0;i0)if(m=MinAdjNode(n)!=-1)Tn.Nodes.Add(Tm);n=m;Visitedn+;elsen=MinNode(0);if(n0)TMin2.Nodes.Add(TMin1);Visitedn+;listBox1.Items.Add(Vn);treeView1.Nodes.Add(T0);voidTopoSort()inti,n;listBox1.Items.Clear();StackS=newStack();for(i=0;i=0;i-)if(InDegree(i)=0)S.Push(i);Visited+;while(S.Count!=0)n=(int)S.Pop();listBox1.Items.Add(Vn);ClearLink(n);for(i=VerNum-1;i=0;i-)if(Visited=0&InDegree(i)=0)S.Push(i);Visited+;voidAOETrave(intn,TreeNodeTR,intw)inti,w0;if(OutDegree(n)=0)return;for(i=0;iVerNum;i+)if(w0=Arcn,i)!=0)listBox1.Items.Add(V+t+(w+w0).ToString()+t+i.ToString()+t+n.ToString();TreeNodeT1=newTreeNode();T1.Text=V+W=+(w+w0).ToString()+;TR.Nodes.Add(T1);AOETrave(i,T1,w+w0);voidAOE()inti,w=0,m=1;TreeNodeT1=newTreeNode();for(i=0;iVerNum;i+)Visited=0;T1.Text=V0;listBox1.Items.Add(雙親表示法顯示這個(gè)生成樹:);listBox1.Items.Add(VtWtIDtPID);for(i=0;iVerNum;i+)if(w=Arc0,i)!=0)listBox1.Items.Add(V+t+w.ToString()+t+i.ToString()+t0);TreeNodeT2=newTreeNode();T2.Text=V+W=+w.ToString()+;AOETrave(i,T2,w);T1.Nodes.Add(T2);listBox1.Items.Add(tt樹+m.ToString();m+;treeView1.Nodes.Clear();treeView1.Nodes.Add(T1);intIsZero()inti;for(i=0;i=0)returni;return-1;in
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 高級(jí)會(huì)計(jì)專業(yè)技能試題及答案深度
- 高級(jí)會(huì)計(jì)考點(diǎn)分析試題及答案
- 消防安全教育實(shí)施方案試題及答案
- 高中職普融通的有效策略與實(shí)施路徑探討
- 廢棄礦山生態(tài)修復(fù)示范工程初步設(shè)計(jì)方案
- 消防工程知識(shí)整合試題及答案分享
- 消防安全責(zé)任與管理機(jī)制的創(chuàng)新探索試題及答案
- 專業(yè)消防工程師試題及答案解析分享
- 消防系統(tǒng)運(yùn)行管理試題及答案
- 精準(zhǔn)掌握2024年無人機(jī)駕駛員考試試題及答案
- 2025年湖北荊州市監(jiān)利市暢惠交通投資有限公司招聘筆試參考題庫含答案解析
- 酒店入股合同協(xié)議書
- 2025-2030中國無煙原煤行業(yè)市場(chǎng)現(xiàn)狀供需分析及市場(chǎng)深度研究發(fā)展前景及規(guī)劃可行性分析研究報(bào)告
- GB/T 32960.3-2025電動(dòng)汽車遠(yuǎn)程服務(wù)與管理系統(tǒng)技術(shù)規(guī)范第3部分:通信協(xié)議及數(shù)據(jù)格式
- 2024年江蘇省勞動(dòng)關(guān)系研究院招聘考試真題
- 2024年四川省公安廳招聘警務(wù)輔助人員真題
- 突發(fā)性聾診療指南(2025版)
- 2025年電子信息工程師職業(yè)資格考試試卷及答案
- 糧食局業(yè)務(wù)知識(shí)課件
- 小學(xué)科學(xué)青島版 (五四制2017)五年級(jí)下冊(cè)26 探索宇宙教案
- 2025年廣東松山職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)傾向性測(cè)試題庫
評(píng)論
0/150
提交評(píng)論