




已閱讀5頁,還剩7頁未讀, 繼續(xù)免費閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
Dijkstra算法Dijkstra算法是典型最短路算法,用于計算一個節(jié)點到其他所有節(jié)點的最短路徑。主要特點是以起始點為中心向外層層擴展,直到擴展到終點為止。Dijkstra算法能得出最短路徑的最優(yōu)解,但由于它遍歷計算的節(jié)點很多,所以效率低。Dijkstra算法是很有代表性的最短路算法,在很多專業(yè)課程中都作為基本內(nèi)容有詳細的介紹,如數(shù)據(jù)結(jié)構(gòu),圖論,運籌學(xué)等等。Dijkstra一般的表述通常有兩種方式,一種用永久和臨時標(biāo)號方式,一種是用OPEN,CLOSE表方式,Drew為了和下面要介紹的A*算法和D*算法表述一致,這里均采用OPEN,CLOSE表的方式。其采用的是貪心法的算法策略大概過程:創(chuàng)建兩個表,OPEN,CLOSE。OPEN表保存所有已生成而未考察的節(jié)點,CLOSED表中記錄已訪問過的節(jié)點。1訪問路網(wǎng)中距離起始點最近且沒有被檢查過的點,把這個點放入OPEN組中等待檢查。2從OPEN表中找出距起始點最近的點,找出這個點的所有子節(jié)點,把這個點放到CLOSE表中。3遍歷考察這個點的子節(jié)點。求出這些子節(jié)點距起始點的距離值,放子節(jié)點到OPEN表中。4重復(fù)第2和第3步,直到OPEN表為空,或找到目標(biāo)點。編輯本段算法實現(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個頂點可以走出的路線,就是復(fù)制第n行到Distancefor(i=0;iVerNum;i+)Distance=Arcn,i;Visited=0;/第n個頂點被訪問,因為第n個頂點是開始點Visitedn=1;/找到該頂點能到其他頂點的路線、并且不是開始的頂點n、以前也沒走過。/相當(dāng)于尋找u點,這個點不是開始點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=2/找完了,MinDis等于不連接,則返回。這種情況類似V5。if(MinDis=No)return;/確立第u個頂點將被使用,相當(dāng)于Arcv,u+Arcu,w中的第u頂點。Visitedu=1;/尋找第u個頂點到其他所有頂點的最小路,實際就是找Arcu,j、j取值在0,VerNum。/如果有Arci,u+Arcu,jArci,j,則Arci,j=Arci,u+Arcu,jArci,j/實際中,因為Distance是要的結(jié)果,對于起始點確定的情況下,就是:/如果(Distanceu+Arcu,j)=Distancej則:/Distancej=Distanceu+Arcu,j;/而iPath保存了u點的編號;/同理:對新找出的路線,要設(shè)置Visitedj=0,以后再找其他路,這個路可能別利用到。例如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(雙親表示法顯示這個生成樹:);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等.壓縮文件請下載最新的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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 勇氣的故事話題作文(7篇)
- 兒童心理衛(wèi)生培訓(xùn)體系構(gòu)建
- 以智慧應(yīng)對困境的話題探討話題作文11篇范文
- 2025至2030中國小麥行業(yè)市場發(fā)展現(xiàn)狀及商業(yè)模式與投資發(fā)展報告
- 基于親子互動促進的寒地商業(yè)綜合體公共空間設(shè)計研究
- 我的新發(fā)現(xiàn)作文400字13篇
- 2025至2030中國宏觀維氏硬度計行業(yè)發(fā)展趨勢分析與未來投資戰(zhàn)略咨詢研究報告
- 2025至2030中國季戊四醇四市場運營格局及前景戰(zhàn)略分析報告
- 2025至2030中國嬰兒手動復(fù)蘇器行業(yè)發(fā)展趨勢分析與未來投資戰(zhàn)略咨詢研究報告
- 2025至2030中國女性奢華面膜行業(yè)發(fā)展趨勢分析與未來投資戰(zhàn)略咨詢研究報告
- T/CNESA 1203-2021壓縮空氣儲能系統(tǒng)性能測試規(guī)范
- T/CGMA 031003-2020一般用離心空氣壓縮機
- 2025年河北省中考乾坤押題卷化學(xué)試卷B及答案
- 2025年四年級下冊美術(shù)期末測試題附答案
- 計量經(jīng)濟學(xué)知到智慧樹期末考試答案題庫2025年南開大學(xué)
- 2025至2030中國天文館行業(yè)投資前景研究與銷售戰(zhàn)略研究報告
- 國開學(xué)習(xí)網(wǎng)《員工招聘與配置》形考任務(wù)1-4答案
- 浙江省諸暨市2025年5月高三適應(yīng)性考試-地理+答案
- 手機使用課件
- 2025年對外漢語教師資格考試試卷及答案
- 配電室安全管理培訓(xùn)課件
評論
0/150
提交評論