數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--弗洛伊德算法與最短路徑_第1頁
已閱讀1頁,還剩9頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、<p>  《數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告》</p><p>  學(xué) 院:信 息 科 學(xué) 技 術(shù) 學(xué) 院 </p><p>  題 目: 弗洛伊德算法與最短路徑 </p><p><b>  一、課程設(shè)計題目</b></p><p>  弗洛伊德算法與最短路徑</p><p>&

2、lt;b>  用途簡介</b></p><p>  1、最短路徑問題在生活中時常見到:比如,我們?nèi)ツ骋坏胤?,我們總是想知道到達(dá)目的地的最短路徑,或者是最短到達(dá)時間。</p><p><b>  2、設(shè)計思路:</b></p><p>  先用迪杰斯特拉算法,找到有向圖中某一頂點到別的頂點的最短路徑,再不斷的調(diào)用我們剛剛寫的迪杰

3、斯特拉算法。最后輸出任意兩點之間的最短路徑。</p><p>  迪杰斯特拉算法的實現(xiàn)方法是,對于有向圖采用鄰接矩陣的方法存放。然后建立兩個數(shù)組,其中一個數(shù)組存放的是某一頂點到這點的最短路徑的值。另一個數(shù)組定義為線性鏈表的表頭單元,然后再數(shù)組后面不斷加入頂點路徑。再在迪杰斯特拉算法內(nèi)部設(shè)一個數(shù)組,用來標(biāo)記頂點元素是否被訪問。每次在尋找權(quán)值最小的且沒有被訪問過得頂點。再加入新頂點后要修正那些還沒有被訪問的點的權(quán)值。

4、</p><p><b>  測試數(shù)據(jù):</b></p><p><b>  測試數(shù)據(jù)表一:</b></p><p>  表一的頂點數(shù)據(jù)在數(shù)組中按下標(biāo)從小到大存放的順序為abcdef。</p><p><b>  測試數(shù)據(jù)表二:</b></p><p>

5、  表一的頂點數(shù)據(jù)在數(shù)組中按下標(biāo)從小到大存放的順序為ABC。</p><p><b>  四、概要設(shè)計</b></p><p>  1、元素類型、結(jié)點類型和指針類型:</p><p>  typedef struct arcnode</p><p><b>  {</b></p>&l

6、t;p><b>  int adj;</b></p><p><b>  }arcnode;</b></p><p>  typedef struct</p><p><b>  {</b></p><p>  char vertex[max];</p>&

7、lt;p>  arcnode arcs[max][max];</p><p>  int vexnum,arcnum;</p><p><b>  }matrix;</b></p><p>  typedef struct linknode</p><p><b>  {</b></p&

8、gt;<p>  char data;</p><p>  struct linknode *next;</p><p>  }linklist;</p><p>  2、建立一個頭結(jié)點數(shù)組path[max],和最短路徑數(shù)組dist[max]:</p><p>  int dist[max],i;</p><

9、p>  linklist path[max];</p><p>  3、主函數(shù)和其他函數(shù):</p><p>  void main()</p><p><b>  {</b></p><p><b>  matrix g;</b></p><p>  creatdn(&

10、amp;g);</p><p>  int dist[max],i;</p><p>  linklist path[max];</p><p>  for(i=1;i<=g.vexnum;i++)//不斷調(diào)用shortestpath(&g,i,dist,path);輸出各頂點間的最短路徑。</p><p><b> 

11、 {</b></p><p>  shortestpath(&g,i,dist,path);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  五、程序代碼:</b></p><p

12、>  #include "stdio.h"</p><p>  #include "stdlib.h"</p><p>  #include "conio.h"</p><p>  #include "dos.h"</p><p>  #define max

13、 10</p><p>  #define inf 3767</p><p>  #define null 0</p><p>  typedef struct arcnode</p><p><b>  {</b></p><p><b>  int adj;</b><

14、;/p><p><b>  }arcnode;</b></p><p>  typedef struct</p><p><b>  {</b></p><p>  char vertex[max];</p><p>  arcnode arcs[max][max];</p

15、><p>  int vexnum,arcnum;</p><p><b>  }matrix;</b></p><p>  void creatdn(matrix *g)</p><p><b>  {</b></p><p>  int i,j,k=0,weight;<

16、/p><p>  printf("%s\n","輸入頂點數(shù)和邊數(shù)");</p><p>  scanf("%d,%d",&g->vexnum,&g->arcnum);</p><p>  for(i=1;i<=g->vexnum;i++)</p><p

17、>  for(j=1;j<=g->vexnum;j++)</p><p><b>  {</b></p><p>  g->arcs[i][j].adj=inf;</p><p><b>  }</b></p><p>  printf("%s\n",&q

18、uot;頂點信息");</p><p>  for(k=0;k<=g->vexnum;k++)</p><p><b>  {</b></p><p>  scanf("%c",&g->vertex[k]);</p><p><b>  }</b&g

19、t;</p><p>  printf("%s\n","頂點i與j之間的權(quán)值");</p><p>  for(k=1;k<=g->arcnum;k++)</p><p><b>  {</b></p><p>  scanf("%d,%d,%d",

20、&i,&j,&weight);</p><p>  g->arcs[i][j].adj=weight;</p><p><b>  } </b></p><p>  //printf("%c",g->vertex[0]);</p><p>  //printf(&q

21、uot;%c",g->vertex[1]);</p><p>  //printf("%c",g->vertex[2]);</p><p>  //printf("%c",g->vertex[3]);</p><p>  //printf("%d",g->arcs[0][1

22、]);</p><p><b>  }</b></p><p>  typedef struct linknode</p><p><b>  {</b></p><p>  char data;</p><p>  struct linknode *next;</p&

23、gt;<p>  }linklist;</p><p>  void init(linklist *l)</p><p><b>  {</b></p><p>  //l=(linklist*)malloc(sizeof(linknode));</p><p>  l->next=null;<

24、/p><p><b>  }</b></p><p>  void link(linklist *p,char x)</p><p><b>  {</b></p><p>  linklist *q;</p><p>  q=(linklist*)malloc(sizeof(l

25、inknode));</p><p>  while(p->next!=null)</p><p><b>  {</b></p><p>  p=p->next;</p><p><b>  }</b></p><p>  //q->next=p->

26、next;</p><p>  p->next=q;</p><p>  q->data=x;</p><p>  q->next=null;</p><p><b>  }</b></p><p>  void shortestpath(matrix *g,int c,int

27、dist[max],linklist path[max])</p><p><b>  { </b></p><p>  printf("頂點%d到各個點的最短距離\n",c);</p><p>  int i,t,min,k;</p><p>  int s[max]={0};</p>

28、<p>  linklist *b;</p><p>  for(i=1;i<=g->vexnum;i++)</p><p><b>  {</b></p><p>  init(&path[i]);</p><p>  dist[i]=g->arcs[c][i].adj;<

29、/p><p>  if(dist[i]!=inf)</p><p><b>  {</b></p><p>  link(&path[i],g->vertex[c]);</p><p>  link(&path[i],g->vertex[i]);</p><p><b

30、>  }</b></p><p><b>  }</b></p><p><b>  s[c]=1;</b></p><p>  for(t=1;t<g->vexnum-1;t++)</p><p><b>  {</b></p>&

31、lt;p><b>  min=inf;</b></p><p>  for(i=1;i<=g->vexnum;i++)</p><p>  if((s[i]==0)&&dist[i]<min)</p><p><b>  {</b></p><p><b

32、>  k=i;</b></p><p>  min=dist[i];</p><p><b>  }</b></p><p>  if(min==inf)</p><p><b>  return;</b></p><p><b>  s[k]=1

33、;</b></p><p>  for(i=1;i<=g->vexnum;i++)</p><p>  if((s[i]==0)&&g->arcs[k][i].adj!=inf&&(dist[k]+g->arcs[k][i].adj<dist[i]))</p><p><b>  {

34、</b></p><p>  dist[i]=dist[k]+g->arcs[k][i].adj;</p><p>  b=&path[k];</p><p>  path[i].next=null;</p><p>  while(b->next!=null)</p><p><

35、b>  {</b></p><p>  b=b->next;</p><p>  link(&path[i],b->data);</p><p><b>  }</b></p><p>  link(&path[i],g->vertex[i]);</p>

36、<p><b>  }</b></p><p><b>  }</b></p><p>  for(i=1;i<=g->vexnum;i++)</p><p><b>  {</b></p><p>  printf("%d,%d\n"

37、,i,dist[i]);</p><p><b>  }</b></p><p>  for(i=1;i<=g->vexnum;i++)</p><p><b>  { </b></p><p>  printf("%d",i);</p><p&g

38、t;  linklist *p;</p><p>  p=&path[i];</p><p>  while((p->next!=null))</p><p><b>  { </b></p><p>  p=p->next;</p><p>  printf("%c

39、",p->data);</p><p><b>  }</b></p><p>  printf("\n");</p><p><b>  }</b></p><p>  printf("\n");</p><p>&l

40、t;b>  }</b></p><p>  void main()</p><p><b>  {</b></p><p><b>  matrix g;</b></p><p>  creatdn(&g);</p><p>  int dist[m

41、ax],i;</p><p>  linklist path[max];</p><p>  for(i=1;i<=g.vexnum;i++)</p><p><b>  {</b></p><p>  shortestpath(&g,i,dist,path);</p><p>&l

42、t;b>  }</b></p><p><b>  }</b></p><p><b>  六、測試結(jié)果:</b></p><p><b>  測試數(shù)據(jù)表一結(jié)果:</b></p><p><b>  測試數(shù)據(jù)表二結(jié)果:</b></p

43、><p><b>  八、心得體會及總結(jié)</b></p><p>  在學(xué)習(xí)這門課程之前,腦海中認(rèn)為只要根據(jù)問題用編程語言解決它就好了,談什么數(shù)據(jù)結(jié)構(gòu),有什么意義?現(xiàn)在看來這是多么的幼稚、荒唐的想法,同時也對這門有了全新的認(rèn)識。</p><p>  下面是我的一點學(xué)習(xí)體會: </p><p>  首先要意識到這門課

44、程的重要性及實踐性;如何合理地組織數(shù)據(jù)、高效地處理數(shù)據(jù)是擴大計算機應(yīng)用領(lǐng)域、提高軟件效率的關(guān)鍵。正如我參加的“ACM程序設(shè)計大賽”一樣,雖然你能把那個問題解決,但是當(dāng)它給你規(guī)定一定的時間時,就解決不了,而其它的人卻能實現(xiàn),這是為什么呢?這里面就是在算法的時間性能上存在很大的差距,你不會選擇合理的數(shù)據(jù)結(jié)構(gòu)、有效地組織數(shù)據(jù),當(dāng)然是無法實現(xiàn)的。還有這門課程的實踐性很強,如果只是“聽”和“讀”,那根本是不可能掌握它的。例如關(guān)于排序的那幾種算法,

45、只有用實例走算法才能體會到它們之間的異同、才能掌握它。 </p><p>  其次我認(rèn)為要理解、“吃透”有關(guān)的概念;因為所有的知識框架都建立在這些基礎(chǔ)概念之上,沒有了它,何談?wù)莆???dāng)然對這些概念絕不是那種死記硬背,那是沒用的。在這里,王教授的從實際中找例子的學(xué)習(xí)方法,我感覺就十分的好。比如隊列的“先進(jìn)先出”的原則,就和現(xiàn)實生活中排隊買票、打飯等一樣嗎?通過與實際相結(jié)合方法,讓我們就能很輕松的理解它。&#

46、160;</p><p>  接下來是關(guān)于算法的學(xué)習(xí);對于一個算法,在上課時聽老師講過之后,可能感覺自己已經(jīng)掌握了,但當(dāng)自己再去看它時又似懂非懂的說不明白。這就是很顯然的沒有掌握嘛!記得王教授經(jīng)常說,回來以后找例子走一遍,只有付出努力,才能真正掌握它。這是絕對有效的,當(dāng)多走幾遍后,不僅能更加深入領(lǐng)會算法思想,而且還能發(fā)現(xiàn)算法的巧妙之處,從而對其產(chǎn)生興趣。 </p><p>  最

溫馨提示

  • 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論