版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、<p> 畢 業(yè) 論 文</p><p> 題 目: 用Floyd算法實現(xiàn)對校園教學</p><p> 樓間的路徑的計算 </p><p> 學 院: 計算機科學與工程學院 </p><p> 專 業(yè): 計算機科學與技術 </p>
2、<p> 畢業(yè)年限: </p><p> 學生姓名: </p><p> 學 號: </p><p> 指導教師: </p><p> 用Floyd算法
3、計算校園教學樓間的路徑</p><p> 摘要:最短路徑是圖論中的一個重要問題,具有很高的實用價值,在地圖中尋找最佳路徑就是其重要的價值之一。本文章通過個人的經(jīng)驗,草擬了一份師大個教學樓間的帶權圖,用鄰接矩陣存儲,并通過求解網(wǎng)絡中任意兩點之間最短路徑的高效方法Floyd算法來實現(xiàn)查找從一個教學樓到另一個教學樓的最短有效路徑,為了便于實際操作,并用java中的swing組件實現(xiàn)簡單的圖形界面。</p>
4、<p> 關鍵字:Floyd算法,鄰接矩陣,最短路徑,JavaSwing組件編程,圖的應用。</p><p><b> 目錄</b></p><p> 1西北師大教學樓的簡單分布圖3</p><p><b> 2 圖的簡介4</b></p><p> 2.1圖的基本概念
5、4</p><p> 2.2圖的存儲結(jié)構(gòu)4</p><p> 2.2.1 鄰接矩陣的數(shù)據(jù)類型5</p><p> 2.2.2 鄰接矩陣存儲方法5</p><p> 2.2.3 鄰接矩陣的特點6</p><p> 3 最短路徑算法的介紹6</p><p><b>
6、3.1最短路徑6</b></p><p> 3.1.1 最短路徑的算法6</p><p> 3.1.2 Dijkstra算法7</p><p> 3.1.3Floyd算法8</p><p> 3.1.4兩種算法的比較9</p><p><b> 4編程實現(xiàn)10</b&
7、gt;</p><p> 4.1編程語言的介紹10</p><p> 4.2程序?qū)崿F(xiàn)的流程圖10</p><p> 4.3程序源代碼11</p><p> 4.3.1 圖形界面的的源代碼。11</p><p> 4.3.2 最短路徑算法的代碼。12</p><p> 4.3
8、.3運行程序14</p><p><b> 參考文獻15</b></p><p><b> 5結(jié)束語16</b></p><p> 1西北師大教學樓的簡單分布圖</p><p> 下面是我畫的師大一些重要的教學樓的分布圖,如圖1-1</p><p> 圖1
9、-1.西北師大教學樓的簡單分布圖</p><p><b> 2 圖的簡介</b></p><p><b> 2.1圖的基本概念</b></p><p> 圖(Graph)由兩個集合V(vertex)和E(edge)組成,記為G = (V , E),其中,V是定頂點的集合,記為V(G),E是兩個不同頂點(頂點對)邊的有
10、限集合,記為E(G)。</p><p><b> 2.2圖的存儲結(jié)構(gòu)</b></p><p> 圖的存儲除了要存儲個頂點本身的信息外,還要存儲定點與定點之間所有的關系(邊的關系),圖的存儲結(jié)構(gòu)一般有四種,分別是鄰接矩陣、鄰接表、十字鄰接表存儲、鄰接多重表存儲。</p><p> 由于用鄰接矩陣存儲有利于最短路徑算法的實現(xiàn),而且圖中的定點數(shù)
11、目有限,故本文章用鄰接矩陣存儲圖中的信息。</p><p> 2.2.1 鄰接矩陣的數(shù)據(jù)類型</p><p> 鄰接矩陣的數(shù)據(jù)類型定義如下:</p><p> define MAXV 99//最大頂點個數(shù)</p><p> Class VertexType</p><p><b> {</b&
12、gt;</p><p> int no;//頂點編號</p><p> InfoType info;//頂點其他信息</p><p><b> };</b></p><p> public class MGraph</p><p><b> {</b></p&
13、gt;<p> int edges[MAXV][MAXV];//鄰接矩陣</p><p> int n,e;//頂點數(shù),弧數(shù)</p><p> VertexType vexs[MAXV];//存放頂點信息 </p><p><b> };</b></p><p> 2.2.2 鄰接矩陣存儲方法
14、</p><p> 鄰接矩陣是表示頂點之間相鄰關系的矩陣。設G= (V , E)是具有n(n > 0)個頂點的圖,頂點的順序依次為(v0,v1,...,vn-1),則G的鄰接矩陣A是n階方陣,其定義如下:</p><p> ?。?)如果G是無向圖,則:</p><p> A[i][j] = </p><p> ?。?) 如果G是有
15、向圖,則: </p><p> A[i][j] = </p><p> (3)如果G是帶權無向圖,則:</p><p> A[i][j] = </p><p> (4)如果G是帶權有向圖,則:</p><p> A[i][j] = </p><p> 2.2.3 鄰接矩陣的特點&
16、lt;/p><p> 鄰接矩陣的特點如下:</p><p> 鄰接矩陣的表示是唯一的。</p><p> 無向圖的鄰接矩陣是一個對稱矩陣,可以用壓縮存儲的方法存儲。</p><p> 用鄰接矩陣的方法存儲圖,要確定圖中有多少邊,則按行、按列對每個元素進行檢測,所花費的時間代價很大, 但是很容易確定圖中任意兩點之間是否有邊相連。</p
17、><p> 3 最短路徑算法的介紹</p><p><b> 3.1最短路徑</b></p><p> 3.1.1 最短路徑的算法</p><p> 在一個帶權的圖中,若從一個頂點到另一個頂點存在路徑,則通常把一條路徑上的權值之和定義為該路徑上的長度或稱為帶權路徑長度。從原點到終點可能不止一條路徑,把帶權路徑長度最短
18、的那條路徑稱為最短路徑,其路徑長度(權值之和)稱為最短路徑的長度或者最短距離。</p><p> 圖的最短路徑有兩方面的問題:求圖中一頂點到其他頂點的最短路徑,可以用Dijkstra算法實現(xiàn);求圖中每一對定點之間的最短路徑,實現(xiàn)方法有兩種:一是分別以圖中的每個頂點為源點共調(diào)用n次Dijkstra算法;另外還有一種算法:Floyd算法。</p><p> 3.1.2 Dijkstra算法
19、</p><p> Dijkstra算法的基本思想為:設G(V,E)是一個帶權有向圖,把圖中的頂點集合分為兩組,第一組為已求出最短路徑的頂點集合(用S表示,初始時,S中只有一個初始點,以后每求得一條最短路徑v, … ,v,就將v加入集合中知道全部頂點加入S集合中,算法就結(jié)束了),第二組為其余未確定最短路徑的集合(用U表示),按最短路徑長度的遞增次序,將頂點加入S中。</p><p>
20、在向S中添加頂點式時,總保持從源點v到S中的個頂點中的最短路徑長度不大于從源點到U中任何頂點最短路徑的長度,例如,若向S中添加的頂點是k,對于U中的內(nèi)一個頂點u,若頂點k到頂點u有邊(權值為w),且原來從頂點v到頂點u的長度(c)大于從頂點v到頂點頂點k(c)與w之和,即 c > c + w,如圖3-1所示,則將v=>k=>u的路徑作為新的最短路徑。</p><p> 實際上,從頂點v到頂點u
21、的這條新的最短路徑是只包括S中的頂點為中間點的當前最短路徑的長度,隨著S中的頂點增加,當S包含所有頂點時,這條新的最短路徑就是最終的最短路徑</p><p> 圖3-1 從頂點v到u的路徑比較。</p><p> Dijkstra算法的具體步驟描述如下:</p><p> 步驟(1) 初始化:</p><p> S = {v}(v是
22、源點),</p><p> dist[v][i] = i = (0, …,n-1),</p><p> path[i] = </p><p> 步驟(2) w = min{w}, i,kS(把頂點k加入S中)。</p><p> 步驟(3) c > c + w 則c = c + w,path[u] = k。</p&
23、gt;<p> 步驟(4) 重復步驟(2)和步驟(3),直到所有的頂點加入S中。</p><p><b> Floyd算法</b></p><p> Floyd算法思想可用如下表達式描述:</p><p> A[i,j] = cost[i,j] (假設圖G= (V,E)采用鄰接矩陣cost存儲)</p>
24、<p> A[i,j] = min{A[i,j],A[i,k+1] A[k+1,j]}(-1= <k <= n-2)</p><p> 該式是一個迭代表達式,A表示已經(jīng)考慮頂點0,…,k等頂點后各頂點之間的最短路徑,那么A[i,j]表示有v到v已經(jīng)考慮頂點0,…,k等頂點后各頂點之間的最短路徑,在此基礎上在考慮頂點k+1,求出v到v考慮了頂點k+1后的最短路徑,也就是最徑的解。</
25、p><p> 若A[i,j]已求出,頂點i到頂點k+1的路徑長度為A[i,k+1],頂點k+1到頂點j的路徑長度為A[k+1,j],現(xiàn)在考慮頂點k+1,如圖3-2所示,如果A[i,k+1] +A[i,k+1]< A[i,j],則將原來頂點i到頂點j的路徑改為:從頂點i到頂點k+1,再從頂點k+1到頂點j,A[i,j] = A[i,k+1] +A[i,k+1];否則,A[i,j] = A[i,j],即不需要修改
26、頂點i到頂點j的路徑。</p><p> 圖 3-2 若A[i,k+1] +A[i,k+1]< A[i,j],修改路徑</p><p> Floyd算法的具體描述:</p><p> Procedure Floyd(GA,A,P);</p><p><b> Begin</b></p><
27、;p> For i:=1 To n Do {最短路徑長度數(shù)組和最短路徑數(shù)組初始化}</p><p> For j:=1 To n Do</p><p><b> Begin</b></p><p> A[i,j]:=GA[i,j];</p><p> P[i,j]:=-1;</p>
28、<p><b> End;</b></p><p> For k:=1 To n Do {n次運算}</p><p> For i:=1 To n Do</p><p> For j:=1 To n Do</p><p><b> Begin</b></p>
29、;<p> If (i=k)or(j=k)or(i=j) Then Continue;{無需計算,直接進入一輪循環(huán)}</p><p> If A[i,k]+A[k,j]<A[i,j] Then Begin {找到更短路徑、保存}</p><p> A[i,j]:= A[i,k]+A[k,j];{ A[i,j]用于保存最短路徑長度}</p><p
30、> P[i,j]:= k;{ P[i,j]用于保存最短路徑}</p><p><b> End;</b></p><p><b> End;</b></p><p><b> End;</b></p><p> 3.1.4兩種算法的比較</p>&
31、lt;p> 正如3.1.1節(jié)所述,求圖中每一對定點之間的最短路徑,實現(xiàn)方法有兩種:一是分別以圖中的每個頂點為源點共調(diào)用n次Dijkstra算法,這種算法的時間復雜度為O(n);另外還有一種算法:Floyd算法,它的時間復雜度仍然為O(n),但思路簡單,本文采用Floyd算法。</p><p><b> 4編程實現(xiàn)</b></p><p> 4.1編程語言的
32、介紹</p><p> 本文章的小程序是用Java編程語言編寫的, Java是由Sun Microsystems公司于1995年5月推出的Java程序設計語言(以下簡稱Java語言)和Java平臺的總稱。用Java實現(xiàn)的HotJava瀏覽器(支持Java applet)顯示了Java的魅力:跨平臺、動態(tài)的Web、Internet計算。從此,Java被廣泛接受并推動了Web的迅速發(fā)展,常用的瀏覽器現(xiàn)在均支持Jav
33、a applet。另一方面,Java技術也不斷更新。</p><p> Java平臺由Java虛擬機(Java Virtual Machine)和Java 應用編程接口(Application Programming Interface、簡稱API)構(gòu)成。Java 應用編程接口為Java應用提供了一個獨立于操作系統(tǒng)的標準接口,可分為基本部分和擴展部分。在硬件或操作系統(tǒng)平臺上安裝一個Java平臺之后,Java應用
34、程序就可運行?,F(xiàn)在Java平臺已經(jīng)嵌入了幾乎所有的操作系統(tǒng)。這樣Java程序可以只編譯一次,就可以在各種系統(tǒng)中運行。Java應用編程接口已經(jīng)從1.1x版發(fā)展到1.2版。目前常用的Java平臺基于Java1.4,最近版本為Java1.7。</p><p> Java分為三個體系J2SE(Java2 Standard Edition),J2EE(Java 2 Platform,Enterprise Edition)
35、,J2ME(Java 2 Micro Edition)。</p><p> Java是一種簡單的,面向?qū)ο蟮?,分布式的,解釋型的,健壯安全的,結(jié)構(gòu)中立的,可移植的,性能優(yōu)異、多線程的動態(tài)語言。</p><p> 4.2程序?qū)崿F(xiàn)的流程圖</p><p> 程序設計流程如圖4-1所示:</p><p> 圖4-1 程序設計思想流程圖<
36、;/p><p><b> 4.3程序源代碼</b></p><p> 4.3.1 圖形界面的的源代碼。</p><p> //布局管理器設為空</p><p> setLayout(null);</p><p> //起點下拉列表設置。</p><p> jComb
37、oBox1 = new JComboBox(Start); </p><p> //設置jComboBox1對象的帶標題邊框</p><p> jComboBox1.setBorder(BorderFactory.createTitledBorder("請選擇起點:"));</p><p> //設置jComboBox1對象在JFrame中
38、的位置。</p><p> jComboBox1.setBounds(20,0,120,50);</p><p> //把控件加入JFrame中</p><p> add(jComboBox1);</p><p> //終點下拉列表設置</p><p> jComboBox2 = new JComboBox(
39、End);</p><p> jComboBox2.setBorder(BorderFactory.createTitledBorder("請選擇終點:"));</p><p> jComboBox2.setBounds(170,0,120,50);</p><p> add(jComboBox2);</p><p>
40、;<b> //查找按鈕設置</b></p><p> JButton jb = new JButton("查找");</p><p> jb.setBounds(220,55,60,25);</p><p> jb.addActionListener(this);</p><p><b
41、> add(jb);</b></p><p><b> //顯示標簽設置</b></p><p> JLabel jl1 = new JLabel("最短路徑為:");</p><p> jl1.setBounds(10,90,80,30);</p><p><b>
42、; add(jl1);</b></p><p><b> //顯示文本設置</b></p><p> textarea = new TextArea();</p><p> textarea.setBounds(30,130,250,40);</p><p><b> //設置窗口標題&l
43、t;/b></p><p> setTitle("校園小幫手");</p><p> add(textarea);</p><p> //設置本窗體顯示的初始大小</p><p> setSize(320,220);</p><p> //設置本窗體初始可見</p>&
44、lt;p> setVisible(true);</p><p> 4.3.2 最短路徑算法的代碼。</p><p><b> //floyd算法</b></p><p> public static ArrayList<Integer[][]> flody(Integer[][] dist) {</p>
45、<p> Integer[][] path=new Integer[dist.length][dist.length];//存儲的是從i->j經(jīng)過的最后一個節(jié)點</p><p> for (int i = 0; i < dist.length; i++) {//初始化路徑path </p><p> for (int j = 0; j < dist[i
46、].length; j++) </p><p> path[i][j]=-1;</p><p><b> }</b></p><p> for(int k=0;k<dist.length;k++){//開始最短路徑的計算</p><p> for (int i = 0; i < dist.length
47、; i++) </p><p><b> {</b></p><p> if(i == k)continue;</p><p><b> else{</b></p><p> for(int j = 0; j < dist.length; j++) </p><p&
48、gt;<b> {</b></p><p> if((j==k)||(i==j))</p><p><b> continue;</b></p><p><b> else</b></p><p><b> {</b></p>&l
49、t;p> if(dist[i][j] > (dist[i][k]+ dist[k][j]))</p><p> { //修改路徑</p><p> path[i][j]=k;//存儲的是從i->j經(jīng)過的最后一個節(jié)點</p><p> dist[i][j]=(dist[i][k] + dist[k][j]); </p>
50、<p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><
51、;p><b> }</b></p><p> ArrayList<Integer[][]> list =new ArrayList<Integer[][]>();</p><p> list.add(dist);</p><p> list.add(path);</p><p>
52、return list;</p><p><b> }</b></p><p><b> 運行程序</b></p><p><b> 選擇起點</b></p><p><b> 選擇終點</b></p><p><b&
53、gt; (3)查找路徑</b></p><p><b> 參考文獻</b></p><p> 李春葆. 數(shù)據(jù)結(jié)構(gòu)教程.[第二版].北京.清華大學出版社.2007</p><p> Robert L.Kruse、Alexander J.Ryba .數(shù)據(jù)結(jié)構(gòu)與程序設計.[影印版].北京.高等教育出版社.2001</p>
54、;<p> 陳浩 等.Java應用開發(fā)指南.[珍藏版].北京.清華大學出版社</p><p> 譚浩強.C++程序設計.北京.清華大學出版社.2006</p><p> William.J.Collins.陳曙暉.數(shù)據(jù)結(jié)構(gòu)和Java集合框架.北京.清華大學出版社</p><p> 李鐘尉、陳丹丹.Java開發(fā)實戰(zhàn)1200例[第二卷].北京.清華
55、大學出版社.2011</p><p> 郝自軍 、何尚錄.最短路問題的Floyd算法的若干討論. 重慶工學院學報(自然科學). 2008.05</p><p><b> 結(jié)束語</b></p><p> 畢業(yè)設計終于完成了,除了變得輕松和釋然外,心里還有遺憾和失落,就像一個長跑運動員跑完了自己的賽程,是不是第一并不重要,關鍵是自己努力了,
56、堅持下來了,自己終于跑到終點了。</p><p> 記得上次寫學年論文時雖然很早就準備了,但由于第一次寫論文設計,準備了一大堆東西,卻很混亂,沒條理,感謝老師的細心指導,通過多次修改完善包括代碼設計和論文內(nèi)容,還有論文格式,我終于完成了。</p><p> 寫學年論文的經(jīng)歷使我這次寫畢業(yè)論文變得成熟多了,我先聯(lián)系導師獲得了論文題目,老師問我能否做一個關于圖的論文時,我說可以,其實,圖對
57、我來說,是一塊很讓自己頭疼的內(nèi)容,但喜歡挑戰(zhàn)的我還是雄心勃勃的決定做一個關于圖的畢業(yè)設計。</p><p> 我先從網(wǎng)上查詢關于圖的應用,如郵遞員問題、城市掃雪問題、乘坐公交車問題等,于是,我就將目標鎖定在關于圖的最短路徑問題上,最短路徑的問題老師講過,而且,與我們的生活息息相關。由于時間有限,我決定做一個與圖有關的小應用程序,是關于我非常熟悉的校園中各個教學樓間的路徑的探索。</p><p
58、> 終于搞清楚了圖的基本術語、圖的存儲、最短路徑的算法。我先開始寫代碼,雖然代碼不多,但仍然困難重重,代碼編寫邏輯雖合理,卻運行不出正確的結(jié)果。</p><p> 代碼編寫通過后,我舒了一口氣,接下來將最短路徑‘融入’實際生活中,</p><p> 平時東南西北不分的的自己開始硬頭皮勾畫校園教學樓網(wǎng)絡分布圖,并根據(jù)自己平時的經(jīng)驗給每條路上加了相應的權值。</p>
59、<p> 接下來是小應用程序界面的設計,為了在圖形界面中正確顯示出最終結(jié)果,讓我花了很多時間和心思。</p><p> 我的畢業(yè)設計也完成了,同時非常感謝指導老師珍貴的意見,由于時間有限,有很多地方還需要完善,如Floyd算法的優(yōu)化設計,應用程序小界面更加的有好美觀等。還需要自己更多的努力。</p><p> 說 明:1. 成績評定均采用五級分制,即優(yōu)、良、中、及格、不及格
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 畢業(yè)論文計算機科學與技術
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術畢業(yè)論文
- 計算機科學與技術專業(yè)畢業(yè)論文
- 計算機科學與技術畢業(yè)論文_1501891104
- 計算機科學與技術專業(yè)畢業(yè)論文
- 計算機科學與技術畢業(yè)論文--酒店網(wǎng)絡
- 有關計算機科學與技術專業(yè)畢業(yè)論文
- 計算機科學與技術專業(yè)畢業(yè)論文規(guī)范
- 計算機科學與技術畢業(yè)論文范文
- 計算機科學與技術專業(yè)畢業(yè)論文(設計)
評論
0/150
提交評論