課程設(shè)計(jì)-圖的遍歷_第1頁(yè)
已閱讀1頁(yè),還剩24頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、<p><b>  目錄</b></p><p>  一、課題的主要功能2</p><p><b>  1.1設(shè)計(jì)內(nèi)容2</b></p><p>  1.2對(duì)課程設(shè)計(jì)功能的需求分析2</p><p>  二、課題的功能模塊的劃分2</p><p><b

2、>  2.1模塊劃分2</b></p><p>  2.2系統(tǒng)的概要設(shè)計(jì)3</p><p>  三、主要功能的實(shí)現(xiàn)4</p><p><b>  3.1算法思想4</b></p><p>  1.圖的鄰接矩陣的建立4</p><p>  2.圖的遍歷的實(shí)現(xiàn)4</

3、p><p><b>  3.2數(shù)據(jù)結(jié)構(gòu)4</b></p><p>  3.3主函數(shù)流程圖5</p><p>  3.4深度優(yōu)先遍歷流程圖6</p><p>  3.5深度優(yōu)先遍歷遞歸7</p><p>  3.6深度優(yōu)先遍歷流程圖9</p><p>  3.7廣度優(yōu)先

4、遍歷遞歸流程圖10</p><p><b>  四、程序調(diào)試11</b></p><p>  4.1程序的調(diào)試分析11</p><p>  4.2程序的測(cè)試結(jié)果11</p><p><b>  五、總結(jié)16</b></p><p><b>  六、附件1

5、6</b></p><p><b>  6.1源程序16</b></p><p><b>  一、課題的主要功能</b></p><p><b>  1.1設(shè)計(jì)內(nèi)容</b></p><p>  演示圖的深度優(yōu)先, 廣度優(yōu)先遍歷過(guò)程,并輸出原圖結(jié)構(gòu)及遍歷結(jié)果。要求圖

6、的結(jié)點(diǎn)數(shù)不能少于6個(gè)。可以由系統(tǒng)隨機(jī)生成圖,也可以由用戶(hù)手動(dòng)輸入圖。報(bào)告中要寫(xiě)出畫(huà)圖的思路;畫(huà)出圖的結(jié)構(gòu),有興趣的同學(xué)可以進(jìn)一步改進(jìn)圖的效果。</p><p>  1.2對(duì)課程設(shè)計(jì)功能的需求分析</p><p>  圖的遍歷并不需要是一個(gè)過(guò)于復(fù)雜的工作環(huán)境,一般來(lái)說(shuō):最合適的才是最好的。軟件設(shè)計(jì)必須符合我們使用實(shí)際情況的需要。根據(jù)要求,圖的遍歷主要功能如下:</p><

7、p>  1.用戶(hù)可以隨時(shí)建立一個(gè)有向圖或無(wú)向圖;</p><p>  2.用戶(hù)可以根據(jù)自己的需要,對(duì)圖進(jìn)行深度遍歷或廣度遍歷;</p><p>  3.用戶(hù)可以根據(jù)自己的需要對(duì)圖進(jìn)行修改;</p><p>  4.在整個(gè)程序中,用戶(hù)可以不斷的按照不同的方式對(duì)圖進(jìn)行遍歷,若不繼續(xù),用戶(hù)也可以隨時(shí)跳出程序,同時(shí),如果用戶(hù)輸入的序號(hào)錯(cuò)誤,程序會(huì)提示用戶(hù)重新輸入序號(hào);

8、</p><p>  二、課題的功能模塊的劃分</p><p><b>  2.1模塊劃分</b></p><p>  1.隊(duì)列的初始化、進(jìn)隊(duì)、出隊(duì)、隊(duì)列空、隊(duì)列滿(mǎn)的函數(shù)</p><p>  void InitQueue(CirQueue *Q) //初始化隊(duì)列</p><p>  int Qu

9、eueEmpty(CirQueue *Q)//隊(duì)列是否為空</p><p>  int QueueFull(CirQueue *Q)//隊(duì)列滿(mǎn)</p><p>  Void EnQueue(CirQueue *Q,int x)//將隊(duì)員進(jìn)隊(duì)</p><p>  int DeQueue(CirQueue *Q)//將隊(duì)員出隊(duì)</p><p&g

10、t;<b>  2.創(chuàng)建圖的函數(shù)</b></p><p>  void CreateMGraph(MGraph *G)//根據(jù)用戶(hù)需要?jiǎng)?chuàng)建一個(gè)圖</p><p>  3.圖的深度優(yōu)先遍歷遞歸</p><p>  void DFSM(MGraph *G,int i)/*含有輸出已訪(fǎng)問(wèn)的頂點(diǎn)的語(yǔ)句*/</p><p>  4

11、.圖的廣度優(yōu)先遍歷遞歸 </p><p>  void BFSM(MGraph *G,int k) /*含有輸出已訪(fǎng)問(wèn)的頂點(diǎn)的語(yǔ)句*/</p><p><b>  5.深度優(yōu)先遍歷 </b></p><p>  void DFSTraverseM(MGraph *G)/*調(diào)用DFSM函數(shù)*/</p><p><b&

12、gt;  6.廣度優(yōu)先遍歷 </b></p><p>  void BFSTraverseM(MGraph *G) /*調(diào)用BFSM函數(shù)*/</p><p><b>  7.主函數(shù) </b></p><p>  main() /*包含一些調(diào)用和控制語(yǔ)句*/</p><p>  2.2系統(tǒng)的概要設(shè)計(jì)</

13、p><p><b>  三、主要功能的實(shí)現(xiàn)</b></p><p><b>  3.1算法思想</b></p><p>  本課題所采用的是鄰接矩陣的方式存儲(chǔ)圖,實(shí)現(xiàn)圖的深度、廣度兩種遍歷,并將每種遍歷結(jié)果輸出來(lái)。</p><p>  1.圖的鄰接矩陣的建立</p><p>  

14、對(duì)任意給定的圖(頂點(diǎn)數(shù)和邊數(shù)自定),根據(jù)鄰接矩陣的存儲(chǔ)結(jié)構(gòu)建立圖的鄰接距陣。</p><p><b>  2.圖的遍歷的實(shí)現(xiàn)</b></p><p>  圖的遍歷包括圖的廣度優(yōu)先遍歷與深度優(yōu)先遍歷。對(duì)于廣度優(yōu)先遍歷應(yīng)利用隊(duì)列的五種基本運(yùn)算(置空隊(duì)列、進(jìn)隊(duì)、出隊(duì)、取隊(duì)頭元素、判隊(duì)空)來(lái)實(shí)現(xiàn)。首先建立一空隊(duì)列,從初始點(diǎn)出發(fā)進(jìn)行訪(fǎng)問(wèn),當(dāng)被訪(fǎng)問(wèn)時(shí)入隊(duì),訪(fǎng)問(wèn)完出隊(duì)。并以隊(duì)列是否

15、為空作為循環(huán)控制條件。對(duì)于深度優(yōu)先遍歷則采用遞歸或非遞歸算法來(lái)實(shí)現(xiàn),這里我所采用的是遞歸算法。</p><p><b>  3.2數(shù)據(jù)結(jié)構(gòu)</b></p><p>  #define Max 10</p><p>  #define FALSE 0</p><p>  #define TRUE 1</p>

16、<p>  #define Error printf</p><p>  #define QueueSize 30</p><p>  typedef struct </p><p><b>  {</b></p><p>  char vexs[Max];</p><p>  int

17、edges[Max][Max];</p><p><b>  int n,e;</b></p><p><b>  }MGraph;</b></p><p>  int visited[Max];</p><p>  typedef struct </p><p><b

18、>  {</b></p><p>  int front;</p><p><b>  int rear;</b></p><p>  int count;</p><p>  int data[QueueSize];</p><p>  }CirQueue;</p>

19、<p><b>  3.3主函數(shù)流程圖</b></p><p>  假 </p><p><b>  0</b></p><p><b>  1</b></p>

20、<p><b>  2 </b></p><p><b>  3</b></p><p>  3.4深度優(yōu)先遍歷流程圖</p><p><b>  真</b></p><p>  非零 零</p><p>  3.

21、5深度優(yōu)先遍歷遞歸</p><p>  真 </p><p>  3.6深度優(yōu)先遍歷流程圖</p><p><b>  真</b></p><p>  非零 零</p><p>  3.7廣度優(yōu)先遍歷遞歸流程圖<

22、/p><p><b>  真</b></p><p><b>  四、程序調(diào)試</b></p><p>  4.1程序的調(diào)試分析</p><p>  在調(diào)試過(guò)程中,程序中出現(xiàn)了許多的錯(cuò)誤,有錯(cuò)誤的調(diào)用,一些變量沒(méi)有定義等等。不斷的對(duì)程序進(jìn)行調(diào)試以得到最好的結(jié)果,程序中特別要注意的是類(lèi)的對(duì)象作為作為參數(shù)時(shí)

23、要注意如何去調(diào)用它,使程序有一個(gè)令人滿(mǎn)意的結(jié)果,具體的調(diào)試是在上機(jī)過(guò)程中進(jìn)行的,在編寫(xiě)程序的過(guò)程中主要有如下錯(cuò)誤:</p><p>  1.在編寫(xiě)程序的過(guò)程出現(xiàn)了一些函數(shù)名、變量的大小寫(xiě)不統(tǒng)一的錯(cuò)誤,導(dǎo)致程序在運(yùn)行的過(guò)程中出現(xiàn)函數(shù)名、變量沒(méi)有被定義等問(wèn)題;</p><p>  2.在編寫(xiě)程序的過(guò)程中數(shù)組的大小寫(xiě)沒(méi)有被確定;</p><p>  3.在編寫(xiě)程序的過(guò)程中

24、一些變量沒(méi)有被定義,導(dǎo)致程序出錯(cuò);</p><p>  4.數(shù)組visited[Max]應(yīng)定義為全局變量,若不是則會(huì)出錯(cuò);</p><p>  5.函數(shù)的返回類(lèi)型要確定,是void還是其他類(lèi)型要十分注意;</p><p>  6.在編程的過(guò)程中,函數(shù)里一些控制語(yǔ)句的嵌套使用,括號(hào)要引起注意,</p><p>  4.2程序的測(cè)試結(jié)果</

25、p><p>  初始進(jìn)入程序時(shí),程序提示按格式輸入圖的頂點(diǎn)個(gè)數(shù)和邊數(shù)。</p><p>  輸入頂點(diǎn)數(shù)和邊數(shù)后,程序提示輸入頂點(diǎn)的序號(hào),為各頂點(diǎn)依次進(jìn)行編號(hào)。</p><p>  將各頂點(diǎn)進(jìn)行編號(hào)后,程序提示按格式輸入邊的頂點(diǎn)序號(hào)。</p><p>  按格式依次輸入邊的頂點(diǎn)序號(hào)后,按enter鍵程序會(huì)出現(xiàn)“選擇菜單”,用戶(hù)根據(jù)需要進(jìn)行選擇。&l

26、t;/p><p>  用戶(hù)選擇2進(jìn)入深度優(yōu)先搜索,并輸出深度優(yōu)先遍歷后的序列,再次輸出菜單欄,進(jìn)行選擇。</p><p>  用戶(hù)再次選擇3進(jìn)入廣度優(yōu)先搜索,并輸出廣度優(yōu)先遍歷后的序列,再次輸出菜單欄,進(jìn)行選擇。</p><p>  用戶(hù)選擇1后進(jìn)入更改數(shù)據(jù),重新創(chuàng)建一個(gè)圖。</p><p>  用戶(hù)選擇0,則退出程序。</p>&

27、lt;p><b>  五、總結(jié)</b></p><p>  通過(guò)這次數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)踐,我學(xué)到了很多東西。本次課程設(shè)計(jì)對(duì)我來(lái)說(shuō)正是一個(gè)提高自己能力的機(jī)會(huì),我好好的抓住機(jī)會(huì),努力做好每一步,完善每一步。自己的C語(yǔ)言知識(shí)和數(shù)據(jù)結(jié)構(gòu)知識(shí)得到了鞏固,編程能力也有了一定的提高。同時(shí)也學(xué)會(huì)了解決問(wèn)題的方法??偨Y(jié)起來(lái),自己主要有以下幾點(diǎn)體會(huì):</p><p>  1.必須牢

28、固掌握基礎(chǔ)知識(shí)。由于C語(yǔ)言是大一所學(xué)知識(shí),有所遺忘,且未掌握好上學(xué)期所學(xué)的《數(shù)據(jù)結(jié)構(gòu)》這門(mén)課,所以在實(shí)踐之初感到棘手。不知如何下手,但在后來(lái)的實(shí)習(xí)過(guò)程中自己通過(guò)看書(shū)和課外資料,并請(qǐng)教其他同學(xué),慢慢地對(duì)C語(yǔ)言和數(shù)據(jù)結(jié)構(gòu)知識(shí)有所熟悉,這時(shí)才逐漸有了思路。所以今后一定要牢固掌握好專(zhuān)業(yè)基礎(chǔ)知識(shí)。</p><p>  2.必須培養(yǎng)嚴(yán)謹(jǐn)?shù)膽B(tài)度。自己在編程時(shí)經(jīng)常因?yàn)橐恍┬″e(cuò)誤而導(dǎo)致出現(xiàn)問(wèn)題,不夠認(rèn)真細(xì)致,這給自己帶來(lái)了許多麻煩

29、。編程是一件十分嚴(yán)謹(jǐn)?shù)氖虑椋莶坏民R虎。所以在今后自己一定要培養(yǎng)嚴(yán)謹(jǐn)?shù)膽B(tài)度。我想這不僅是對(duì)于程序設(shè)計(jì),做任何事都應(yīng)如此。</p><p>  3.這次課程設(shè)計(jì)也讓我充分認(rèn)識(shí)到《數(shù)據(jù)結(jié)構(gòu)》這門(mén)課的重要性。它給我們一個(gè)思想和大綱,讓我們?cè)诰幊虝r(shí)容易找到思路,不至于無(wú)章可循。同時(shí)它也有廣泛的實(shí)際應(yīng)用。</p><p>  在實(shí)踐過(guò)程中,我遇到了許多困難,但都一一克服了。最終我圓滿(mǎn)的完成此次課程設(shè)

30、計(jì),學(xué)到了很多東西。同時(shí),程序還存在著一些缺陷,我會(huì)繼續(xù)努力思考,完善程序,做到最好。</p><p>  總的來(lái)說(shuō),本次課程設(shè)計(jì),不僅我的知識(shí)面有所提高,另外我的綜合素質(zhì)也有所提高,這次課程設(shè)計(jì)為我以后更好的學(xué)習(xí)和使用c語(yǔ)言打下了基礎(chǔ)。</p><p><b>  六、附件</b></p><p><b>  6.1源程序</

31、b></p><p>  #include<stdio.h></p><p>  #include<stdlib.h></p><p>  #define Max 10</p><p>  #define FALSE 0</p><p>  #define TRUE 1</p>

32、<p>  #define Error printf</p><p>  #define QueueSize 30</p><p>  typedef struct </p><p><b>  {</b></p><p>  char vexs[Max];</p><p>  in

33、t edges[Max][Max];</p><p><b>  int n,e;</b></p><p>  }MGraph;/*以鄰接矩陣作為圖的存儲(chǔ)結(jié)構(gòu)*/</p><p>  int visited[Max];/*將visited[Max]定義為全局變量并分配最大空間*/</p><p>  typedef st

34、ruct </p><p><b>  {</b></p><p>  int front;</p><p><b>  int rear;</b></p><p>  int count;</p><p>  int data[QueueSize];</p>

35、<p>  }CirQueue;/*定義隊(duì)列的數(shù)據(jù)結(jié)構(gòu)*/</p><p><b>  //初始化隊(duì)列 </b></p><p>  void InitQueue(CirQueue *Q)</p><p><b>  {</b></p><p>  Q->front=Q->re

36、ar=0;</p><p>  Q->count=0;</p><p><b>  }</b></p><p><b>  //隊(duì)列空</b></p><p>  int QueueEmpty(CirQueue *Q)</p><p><b>  {</

37、b></p><p>  return Q->count=QueueSize;/*返回隊(duì)列的最大長(zhǎng)度*/</p><p><b>  } </b></p><p><b>  //隊(duì)列滿(mǎn)</b></p><p>  int QueueFull(CirQueue *Q)</p>

38、<p><b>  {</b></p><p>  return Q->count==QueueSize;/*返回隊(duì)列的最大長(zhǎng)度*/</p><p><b>  } </b></p><p><b>  //進(jìn)隊(duì)</b></p><p>  void EnQ

39、ueue(CirQueue *Q,int x)</p><p><b>  {</b></p><p>  if(QueueFull(Q))/*隊(duì)列滿(mǎn)則出錯(cuò)*/</p><p><b>  {</b></p><p>  Error("Queue overflow");</

40、p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  Q->count++;/*否則count++,將x進(jìn)隊(duì)*/</p><p>  Q->data[Q-&g

41、t;rear]=x;</p><p>  Q->rear=(Q->rear+1)%QueueSize;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  //出隊(duì)</b></p><p&g

42、t;  int DeQueue(CirQueue *Q)</p><p><b>  {</b></p><p>  int temp;/*定義整型的變量*/</p><p>  if(QueueEmpty(Q))/*若為真則出錯(cuò)*/</p><p><b>  {</b></p>&

43、lt;p>  Error("Queue underflow");</p><p><b>  }</b></p><p>  else/*為假則count--,將隊(duì)員出隊(duì)*/</p><p><b>  {</b></p><p>  temp=Q->data[Q-&

44、gt;front];/*用temp返回其值*/</p><p>  Q->count--;</p><p>  Q->front=(Q->front+1)%QueueSize;</p><p>  return temp;/*返回出隊(duì)元素值*/</p><p><b>  }</b></p>

45、<p><b>  } </b></p><p><b>  //建立一個(gè)圖</b></p><p>  void CreateMGraph(MGraph *G)</p><p><b>  {</b></p><p>  int i,j,k;/*定義整型變量*/

46、</p><p>  char ch1,ch2;/*定義字符型變量*/</p><p>  printf("\n請(qǐng)輸入頂點(diǎn)數(shù),邊數(shù)(格式:3,4):");</p><p>  scanf("%d,%d",&(G->n),&(G->e));/*輸入圖的頂點(diǎn)數(shù)和邊數(shù)*/</p><p

47、>  for(i=0;i<G->n;i++)</p><p><b>  {</b></p><p>  getchar();</p><p>  printf("\n請(qǐng)輸入第%d個(gè)頂點(diǎn)序號(hào)",i+1);</p><p>  scanf("%c",&(G-

48、>vexs[i]));/*輸入頂點(diǎn)的序號(hào)*/</p><p><b>  }</b></p><p>  for(i=0;i<G->n;i++)</p><p><b>  {</b></p><p>  for(j=0;j<G->n;j++)</p>&

49、lt;p><b>  {</b></p><p>  G->edges[i][j]=0;/*初始化矩陣*/</p><p><b>  }</b></p><p><b>  }</b></p><p>  for(k=0;k<G->e;k++)<

50、/p><p><b>  {</b></p><p>  getchar();</p><p>  printf("\n請(qǐng)輸入第%d條邊的頂點(diǎn)序號(hào)(格式:i,j):",k+1);</p><p>  scanf("%c,%c",&ch1,&ch2);/*輸入邊的頂點(diǎn)序號(hào)

51、*/</p><p>  for(i=0;ch1!=G->vexs[i];i++);</p><p>  for(j=0;ch2!=G->vexs[j];j++);</p><p>  G->edges[i][j]=1;/*有邊則賦值為1*/</p><p><b>  }</b></p>

52、<p><b>  } </b></p><p>  //深度優(yōu)先遍歷遞歸 </p><p>  void DFSM(MGraph *G,int i)</p><p><b>  {</b></p><p><b>  int j;</b></p>&

53、lt;p>  printf("%c ",G->vexs[i]);</p><p>  visited[i]=TRUE;/*標(biāo)記visited[i]*/</p><p>  /*依次優(yōu)先搜索訪(fǎng)問(wèn)visited[i]的每個(gè)鄰接點(diǎn)*/</p><p>  for(j=0;j<G->n;j++)</p><p&

54、gt;  /*若visited[i]的一個(gè)有效鄰接點(diǎn)visited[j]未被訪(fǎng)問(wèn)過(guò),則從visited[j]出發(fā)進(jìn)行遞歸調(diào)用*/</p><p>  if(G->edges[i][j]==1&&!visited[j])</p><p>  DFSM(G,j);</p><p><b>  } </b></p>

55、<p>  //廣度優(yōu)先遍歷遞歸</p><p>  void BFSM(MGraph *G,int k)</p><p><b>  {</b></p><p><b>  int i,j;</b></p><p>  CirQueue Q;/*定義一個(gè)隊(duì)列Q,初始化隊(duì)列為空*/<

56、;/p><p>  InitQueue(&Q);</p><p>  printf("%c ",G->vexs[k]);/*訪(fǎng)問(wèn)初始點(diǎn),并將其標(biāo)記已訪(fǎng)問(wèn)過(guò)*/</p><p>  visited[k]=TRUE;</p><p>  EnQueue(&Q,k);/*將以訪(fǎng)問(wèn)過(guò)的初始點(diǎn)序號(hào)k入隊(duì)*/<

57、/p><p>  while(!QueueEmpty(&Q))/*隊(duì)列非空進(jìn)行循環(huán)處理*/</p><p><b>  {</b></p><p>  i=DeQueue(&Q);/*將隊(duì)首元素出隊(duì)*/</p><p>  for(j=0;j<G->n;j++)/*依次搜索vexs[k]的每一個(gè)可

58、能的鄰接點(diǎn)*/</p><p><b>  {</b></p><p>  if(G->edges[i][j]==1 &&! visited[j])</p><p><b>  {</b></p><p>  visited[j]=TRUE;/*標(biāo)記vexs[j]已訪(fǎng)問(wèn)過(guò)*/&

59、lt;/p><p>  EnQueue(&Q,j);/*頂點(diǎn)序號(hào)j入隊(duì)*/</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b&

60、gt;</p><p><b>  //深度優(yōu)先遍歷</b></p><p>  void DFSTraverseM(MGraph *G)</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  pr

61、intf("\n 深度優(yōu)先遍歷序列:");</p><p>  for(i=0;i<G->n;i++)</p><p><b>  {</b></p><p>  visited[i]=FALSE;/*訪(fǎng)問(wèn)標(biāo)志數(shù)組初始化*/</p><p><b>

62、;  }</b></p><p>  for(i=0;i<G->n;i++)</p><p><b>  {</b></p><p>  if(!visited[i])/*對(duì)尚未訪(fǎng)問(wèn)的頂點(diǎn)調(diào)用DFSM*/</p><p><b>  {</b></p><

63、p>  DFSM(G,i);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  } </b></p><p><b>  //廣度優(yōu)先遍歷</b></p><p>  

64、void BFSTraverseM(MGraph *G)</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  printf("\n 廣度優(yōu)先遍歷序列:");</p><p>  for(i=0

65、;i<G->n;i++)</p><p><b>  {</b></p><p>  visited[i]=FALSE;/*訪(fǎng)問(wèn)標(biāo)志數(shù)組初始化*/</p><p><b>  }</b></p><p>  for(i=0;i<G->n;i++)</p><

66、;p><b>  {</b></p><p>  if(!visited[i])/*對(duì)尚未訪(fǎng)問(wèn)的頂點(diǎn)調(diào)用BFSM*/</p><p><b>  {</b></p><p>  BFSM(G,i);</p><p><b>  }</b></p><p

67、><b>  }</b></p><p><b>  } </b></p><p><b>  main()</b></p><p><b>  {</b></p><p>  MGraph *G,a;</p><p><

68、;b>  char ch1;</b></p><p>  int i,j,ch2;</p><p><b>  G=&a;</b></p><p>  printf("\n\t\t 深度優(yōu)先搜索和廣度優(yōu)先搜索 \n");</p><p> 

69、 CreateMGraph(G);/*調(diào)用創(chuàng)建圖矩陣的函數(shù)*/</p><p>  getchar(); </p><p>  ch1='y';/*設(shè)置控制語(yǔ)句標(biāo)志*/</p><p>  while(ch1=='y'||ch1=='Y')</p><p>  { /

70、*菜單欄*/</p><p>  printf("\n");</p><p>  printf(" 選擇菜單"); </p><p>  printf("\n\t\t******************************************

71、\n");</p><p>  printf("\t\t* 更改數(shù)據(jù)請(qǐng)按:1 *\n");</p><p>  printf("\t\t* 深度優(yōu)先搜索請(qǐng)按:2 *\n");</p><p>  printf("\t\t

72、* 廣度優(yōu)先搜索請(qǐng)按:3 *\n");</p><p>  printf("\t\t* 退出搜索請(qǐng)按:0 *\n");</p><p>  printf("\t\t******************************************\n"

73、);</p><p>  printf("\n\t\t請(qǐng)選擇菜單號(hào)(0-3):");</p><p>  scanf("%d",&ch2);</p><p>  getchar();</p><p>  switch(ch2)</p><p><b>  {&l

74、t;/b></p><p><b>  case 1:</b></p><p>  CreateMGraph(G);/*選1創(chuàng)建一個(gè)新的圖矩陣*/</p><p><b>  break;</b></p><p><b>  case 2:</b></p>

75、<p>  DFSTraverseM(G);/*選2進(jìn)入深度優(yōu)先搜索*/</p><p><b>  break;</b></p><p><b>  case 3:</b></p><p>  BFSTraverseM(G);/*選3進(jìn)入廣度優(yōu)先搜索*/</p><p><b>

76、;  break;</b></p><p>  case 0:/*選0結(jié)束搜索,退出程序*/</p><p><b>  ch1='n';</b></p><p><b>  break;</b></p><p><b>  default:</b>

77、</p><p>  system("cls");</p><p>  printf("\n\t\t輸入有誤!\n");</p><p><b>  break;</b></p><p><b>  }</b></p><p>  if

78、(ch2==1||ch2==2||ch2==3)</p><p>  printf("\n\n\t\t ");/*控制格式*/</p><p><b>  }</b></p><p><b>  }</b></p><p>  計(jì)算機(jī)與通信學(xué)院課程設(shè)計(jì)評(píng)分表</p>

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論