拓撲排序課程設計報告_第1頁
已閱讀1頁,還剩10頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  拓撲排序</b></p><p><b>  一 目的</b></p><p>  通過課程設計,加深對《程序設計語言》和《軟件技術基礎》課程所學知識的理解,熟練掌握和鞏固C語言的基本知識和語法規(guī)范,包括:數(shù)據類型(整形、實型、字符型、指針、數(shù)組、結構等);運算類型(算術運算、邏輯運算、自增自減運算、賦值運算等)

2、;程序結構(順序結構、判斷選擇結構、循環(huán)結構);庫函數(shù)應用等;復雜任務功能分解方法(自頂向下逐步求精、模塊化設計、信息隱藏等),熟練掌握和鞏固三種基本圖形結構的邏輯結構、存儲結構以及相關運算和應用。</p><p>  學會編制結構清晰、風格良好、數(shù)據結構適當?shù)腃語言程序,從而具備利用計算機編程分析解決綜合性實際問題的初步能力。</p><p><b>  二 需求分析<

3、;/b></p><p>  題目描述:判斷一個有向圖是否存在回路,并求出有向無環(huán)圖的拓撲序列。</p><p><b>  1、輸入數(shù)據</b></p><p>  在工程文件中保存輸入2個字符串數(shù)TXT文件。第一個為圖按次序排列的所有邊的前頂點,第二個為相對應的第二個頂點。</p><p><b> 

4、 2、輸出數(shù)據</b></p><p>  圖的定點數(shù),邊數(shù),每個頂點的信息及入度,構造的鄰接表,圖的拓撲排序。</p><p><b>  3、程序功能</b></p><p>  已將AOV網存入文件中,運行時從文件讀取數(shù)據;對一個AOV網,應判斷其是否是有向無環(huán)圖,若是則輸出其任意一個拓撲排序序列,不是則進行相關的說明;構造圖

5、的鄰接表;輸出所有頂點的入度。</p><p><b>  三 概要設計</b></p><p>  1、全局變量或類型說明</p><p>  //********結構體定義***********//</p><p>  typedef struct A_Node //定義表結點結構</p><p

6、><b>  {</b></p><p>  int adjvex; //與vi相鄰接的頂點編號</p><p>  struct A_Node *nextarc; //指向下一條弧(邊)的指針</p><p><b>  } A_Node;</b></p><p>  typedef str

7、uct V_Node //定義表頭結點結構</p><p><b>  {</b></p><p><b>  int data;</b></p><p>  A_Node *firstarc; //指向第一條?。ㄟ叄┑闹羔?lt;/p><p>  } V_Node, AdjList[MAX_NUM];

8、</p><p>  typedef struct //定義鄰接表結構</p><p><b>  {</b></p><p>  AdjList vertices; //表頭結點數(shù)組</p><p>  int vex_num, arc_num; //頂點和?。ㄟ叄┑膫€數(shù)</p><p>  }

9、 ALGraph;</p><p>  typedef struct //構件棧</p><p><b>  {</b></p><p>  Elem_T *base;</p><p>  Elem_T *top;</p><p>  int stacksize;</p><p

10、><b>  } Sq;</b></p><p><b>  2、模塊功能</b></p><p>  1) void Init(Sq *S); </p><p>  功能:初始化棧。構造一個空棧S</p><p>  參數(shù):*S 待初始化的棧</p><p>  2)

11、 int Stack(Sq *S)</p><p><b>  功能:判斷空棧</b></p><p>  參數(shù):S 待判斷的棧</p><p>  返回值:棧為空返回 1;棧非空返回 0</p><p>  3) Void Int(Sq *S, Elem_T e)</p><p><b&g

12、t;  功能:元素入棧</b></p><p>  參數(shù):*S 待操作的棧;插入元素e為新的棧頂元素</p><p>  4) void Out(Sq *S, Elem_T e);</p><p><b>  功能:元素出棧</b></p><p>  參數(shù):*S 待操作的棧;若棧不空,則刪除S的棧頂元素,用

13、e返回其值,并返回1;否則返回0</p><p>  5) void Creat_Graph(ALGraph *G)</p><p>  功能:建立圖。函數(shù)內包含了由用戶輸入頂點數(shù)、弧數(shù)、頂點以及弧的操作</p><p>  參數(shù):*G 待操作的圖</p><p>  返回值:圖建立成功返回1;圖建立失敗返回0</p><

14、p>  6) void Find_InDegree(ALGraph G, int indegree[])</p><p><b>  功能:求頂點的入度</b></p><p>  參數(shù):G 待操作的圖,indegree[]儲存每個頂點的入度的數(shù)組</p><p>  7) void TuoPu(ALGraph G);</p>

15、<p>  功能:實現(xiàn)拓撲排序,并在圖形界面上演示排序過程</p><p>  參數(shù):G 待進行拓撲排序的圖</p><p>  錯誤判斷:包含有向圖是否有環(huán)的判斷</p><p><b>  四 詳細設計</b></p><p><b>  源代碼詳情如下:</b></p&g

16、t;<p>  //*****拓撲排序*********//</p><p>  //******張雪濤*********//</p><p>  //*****2013.12.27******//</p><p>  //*****函數(shù)頭文件、宏定義、變量聲明*******//</p><p>  #include<ST

17、DIO.H></p><p>  #include<STDLIB.H></p><p>  #define MAX_NUM 15 </p><p>  #define STACK_SIZE 100</p><p>  #define STACK_MENT 10</p><p>  #define

18、OK 1</p><p>  #define M 20</p><p>  #define ERROR 0</p><p>  #define NUM 15</p><p>  typedef int Elem_T;</p><p>  char number1[NUM];</p><p>  

19、char number2[NUM];</p><p>  //********結構體定義***********//</p><p>  typedef struct A_Node //定義表結點結構</p><p><b>  {</b></p><p>  int adjvex; //與vi相鄰接的頂點編號</p

20、><p>  struct A_Node *nextarc; //指向下一條弧(邊)的指針</p><p><b>  } A_Node;</b></p><p>  typedef struct V_Node //定義表頭結點結構</p><p><b>  {</b></p><

21、p><b>  int data;</b></p><p>  A_Node *firstarc; //指向第一條?。ㄟ叄┑闹羔?lt;/p><p>  } V_Node, AdjList[MAX_NUM];</p><p>  typedef struct //定義鄰接表結構</p><p><b>  {

22、</b></p><p>  AdjList vertices; //表頭結點數(shù)組</p><p>  int vex_num, arc_num; //頂點和?。ㄟ叄┑膫€數(shù)</p><p>  } ALGraph;</p><p>  typedef struct //構件棧</p><p><b&g

23、t;  {</b></p><p>  Elem_T *base;</p><p>  Elem_T *top;</p><p>  int stacksize;</p><p><b>  } Sq;</b></p><p>  //********函數(shù)聲明***********//

24、</p><p>  void Init(Sq *);</p><p>  int Stack(Sq *); </p><p>  void TuoPu(ALGraph);</p><p>  int Out(Sq *, Elem_T);</p><p>  int Int(Sq *, Elem_T *);</p

25、><p>  void Creat_Graph(ALGraph *);</p><p>  void Find_InDegree(ALGraph, int *);</p><p>  //********主函數(shù)***********//</p><p>  int main(void) </p><p><b>

26、  {</b></p><p>  char num='Y';FILE *fp;</p><p>  fp=fopen("num1.txt","r"); //打開num1文件</p><p>  if(fp!=NULL)</p><p><b>

27、;  {</b></p><p>  for(int i=1;i<=NUM;i++){</p><p>  fscanf(fp,"%d",&number1[i]);//將文件的內容讀入number1數(shù)組中</p><p><b>  }</b></p><p>  fclos

28、e(fp); //關閉文件</p><p><b>  }</b></p><p>  fp=fopen("num2.txt","r"); //打開文件num2</p><p>  if(fp!=NULL)</p><

29、p><b>  {</b></p><p>  for(int i=1;i<=NUM;i++){</p><p>  fscanf(fp,"%d",&number2[i]);//讀取文件的內容到number2中</p><p><b>  }</b></p><p

30、>  fclose(fp); //關閉文件</p><p><b>  }</b></p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  printf("

31、\n歡迎您繼續(xù)使用,請選擇 Y or N :"); //判斷是否為Y,若是則繼續(xù)運行,若是N則退出</p><p>  scanf("%c",&num);</p><p>  if(num=='N')</p><p><b>  exit(0);</b></p><p&g

32、t;  ALGraph G;</p><p>  Creat_Graph(&G); //調用函數(shù)創(chuàng)建有向圖</p><p>  TuoPu(G); //進行拓撲排序</p><p><b>  }</b></p><p>

33、<b>  return 0;</b></p><p><b>  }</b></p><p>  void Init(Sq *S) //初始化棧</p><p><b>  {</b></p><p>  S->base

34、 = (Elem_T *) malloc(STACK_SIZE * sizeof (Elem_T));//構建空指針</p><p>  if (!S->base) {</p><p>  printf("memory allocation failed, goodbye");//判斷是否建立成功</p><p><b>  ex

35、it(1);</b></p><p><b>  }</b></p><p>  S->top = S->base;</p><p>  S->stacksize = STACK_SIZE;</p><p><b>  }</b></p><p>

36、;  int Out(Sq *S, Elem_T *e)//出棧操作</p><p><b>  {</b></p><p>  if (S->top == S->base) {</p><p>  return ERROR;</p><p><b>  }</b></p>

37、<p>  *e = *--S->top;</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  void Int(Sq *S, Elem_T e)//進棧操作</p><p><b>  {</b>

38、;</p><p>  if (S->top - S->base >= S->stacksize) {</p><p>  S->base = (Elem_T *) realloc(S->base, (S->stacksize + STACK_MENT) * sizeof (Elem_T));</p><p>  if (!

39、S->base) {</p><p>  printf("memory allocation failed, goodbye");</p><p><b>  exit(1);</b></p><p><b>  }</b></p><p>  S->top = S-

40、>base + S->stacksize;</p><p>  S->stacksize += STACK_MENT;</p><p><b>  }</b></p><p>  *S->top++ = e;</p><p><b>  }</b></p>&l

41、t;p>  int Stack(Sq *S)//判斷棧是否為空</p><p><b>  {</b></p><p>  if (S->top == S->base)</p><p>  return OK;</p><p><b>  else</b></p>&

42、lt;p>  return ERROR;</p><p><b>  }</b></p><p>  void Creat_Graph(ALGraph *G)//構建圖</p><p><b>  {</b></p><p>  int m, n, i,j;</p><p&

43、gt;  A_Node *p;</p><p>  printf("\n***************************************************\n");</p><p>  printf("********* 歡迎您使用拓撲排序 ***********\n");</p><p&

44、gt;  printf("********* 制作者:張雪濤 ***********\n");</p><p>  printf("********* 學號:10056041 ***********\n");</p><p>  printf("********************

45、*******************************\n");</p><p>  printf("請輸入頂點數(shù)和邊數(shù):10 15");</p><p>  G->vex_num=10 ;//要構建的頂點個數(shù)</p><p>  G->arc_num=15;//要構建的邊數(shù)</p><p>

46、  for (i = 1; i <= G->vex_num; i++) {</p><p>  G->vertices[i].data = i;//構建頂點</p><p>  G->vertices[i].firstarc = NULL;</p><p><b>  }</b></p><p>

47、<b>  j=1;</b></p><p>  for (i = 1; i <= G->arc_num; i++) //輸入存在邊的點集合</p><p><b>  {</b></p><p><b>  if(j>15)</b></p><p><

48、b>  { j=1;}</b></p><p>  n=number1[j];//起點數(shù)組</p><p>  m=number2[j];//終點數(shù)組</p><p>  printf("\n 第");</p><p>  printf("%d ",i);</p>&

49、lt;p><b>  if(i>=10)</b></p><p>  printf("條邊的兩頂點序號分別為為:");</p><p><b>  else</b></p><p>  printf(" 條邊的兩頂點序號分別為為:");</p><p&

50、gt;  printf("%d ",n);//打印構建的邊</p><p>  printf("%d",m);</p><p><b>  j++;</b></p><p>  //scanf("%d%d", &n, &m);</p><p> 

51、 while (n < 0 || n > G->vex_num || m < 0 || m > G->vex_num) {</p><p>  printf("\n 輸入的頂點序號不正確 請重新輸入!");</p><p>  printf("\n 第");</p><p>  pr

52、intf("%d ",i);</p><p><b>  if(i>=10)</b></p><p>  printf("條邊的兩頂點序號分別為為:");</p><p><b>  else</b></p><p>  printf(" 條邊

53、的兩頂點序號分別為為:");</p><p>  scanf("%d%d", &n, &m);</p><p><b>  }</b></p><p>  p = (A_Node*) malloc(sizeof (A_Node));//構建空鏈表</p><p>  if (

54、p == NULL) {</p><p>  printf("memory allocation failed,goodbey");</p><p><b>  exit(1);</b></p><p><b>  }</b></p><p>  p->adjvex = m

55、;//表頭指向終點</p><p>  p->nextarc = G->vertices[n].firstarc;</p><p>  G->vertices[n].firstarc = p;</p><p><b>  }</b></p><p><b>  }</b></

56、p><p>  void Find_InDegree(ALGraph G, int indegree[])//找入度為零的節(jié)點</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  for (i = 1; i <= G.vex_num; i+

57、+) {</p><p>  indegree[i] = 0;</p><p><b>  }</b></p><p>  for (i = 1; i <= G.vex_num; i++) {</p><p>  while (G.vertices[i].firstarc) {</p><p&g

58、t;  indegree[G.vertices[i].firstarc->adjvex]++;</p><p>  G.vertices[i].firstarc = G.vertices[i].firstarc->nextarc;</p><p><b>  }</b></p><p><b>  }</b>&

59、lt;/p><p><b>  }</b></p><p>  void TuoPu(ALGraph G) //進行拓撲排序</p><p><b>  {</b></p><p>  int indegree[M];</p><p>  int i, k, n;</p&g

60、t;<p>  int count = 0; //用來統(tǒng)計頂點的個數(shù)</p><p>  A_Node *p; //定義一個棧,用來保存入度為0的頂點</p><p><b>  Sq S;</b></p><p>  Find_InDegree(G, indegree);//查找深度</p><p>  

61、Init(&S);//初始化棧</p><p>  for (i = 1; i <= G.vex_num; i++) {</p><p>  if (!indegree[i])//如果深度為0則入棧</p><p>  Int(&S, i);</p><p><b>  }</b></p>

62、;<p>  if (count < G.vex_num) {</p><p>  printf("\n\n該有向圖有回路!!!\n");</p><p><b>  }</b></p><p><b>  else{</b></p><p>  printf

63、("\n進行拓撲排序輸出順序為:\n"); //輸出結果</p><p>  while (!Stack(&S)) {</p><p>  Out(&S, &n);//出棧</p><p>  printf("%4d", G.vertices[n].data);//打印結果</p><

64、;p><b>  count++;</b></p><p>  for (p = G.vertices[n].firstarc; p != NULL; p = p->nextarc) {</p><p>  k = p->adjvex;</p><p>  if (!(--indegree[k])) //自減若深度為0則入棧&

65、lt;/p><p>  Int(&S, k);//入棧</p><p><b>  }</b></p><p><b>  }</b></p><p>  printf("\n");</p><p>  printf("排序成功\n"

66、;);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  五 調試分析</b></p><p><b>  1、測試數(shù)據</b></p><p><b>  圖的

67、拓撲排序:</b></p><p>  2、存在過的問題以及分析解決</p><p> ?。?)本課程設計采用先把主體結構寫好后在網結構中添加具體的分布功能。采用的是主分式的形式以保證一個功能不能實現(xiàn)并不影響其他的功能。</p><p> ?。?)課程設計有較好的容錯能力,能夠讓一般用戶也不出錯,能正確的輸入信息和統(tǒng)計,保證了正確性。</p>

68、<p> ?。?)修改的時候采用一邊調試一邊修改,并不斷嘗試錯誤輸入和驗證。</p><p><b>  六 測試結果</b></p><p>  測試結果如下圖所示:</p><p><b>  正常使用:</b></p><p><b>  繼續(xù)選擇是否使用:</

69、b></p><p><b>  錯誤的輸入如下:</b></p><p><b>  有回路的操作如下:</b></p><p><b>  七 用戶使用說明</b></p><p>  運行程序前在工程文件中輸入所構造圖的邊頂點并保存,運行后會輸出圖的頂點數(shù),邊數(shù),

70、頂點信息,圖的所有邊數(shù),構造的連接表,每個頂點的入度和有向無環(huán)圖的拓撲排序及對有環(huán)圖進行說明。再按任意鍵,結束程序運行,進行對其他圖的拓撲排序。</p><p><b>  八 課程設計總結</b></p><p>  根據本課程設計的實驗,從中學到了編程其實也是一項很有考驗性的活動,從很大程度上提高了我們對這門課程的了解和學習,并學會從實踐中總結經驗,從實驗中找到

71、方法,通過本次課程設計加深了對所學知識的理解。大家都知道,編程是一件很需要耐心的事。因為幾乎每一個程序的編寫,都需要學習新的知識才能進行,同時程序調試過程很枯燥,有時候一點小錯意味著長時間的查錯。如語法錯誤中,“;”丟失、“{”與“}”不匹配等問題最難定位到出錯語句;邏輯錯誤中,作為循環(huán)變量的“i”與“j”相互混淆、對未分配空間的節(jié)點進行操作等,都會使程序運行出錯而難以找到原因。算法設計、程序調試的過程中,經常遇到看似簡單但又無法解決的

72、問題,這時候很容易灰心喪氣,此時切不可煩躁,一定要冷靜的思考,認真的分析;而解決問題,完成程序后,那種興奮感與成就感也令人振奮??梢哉f編寫程序既是一件艱苦的工作,又是一件愉快的事情。</p><p>  在完成課程設計的過程中,我加深了對程序結構的了解程度,對各種語句理解也更透徹,學會了靈活運用。同時體會到了團隊合作的樂趣,一向慣于“獨立思考”的我們學會了積極地同團隊成員交流,取長補短,共同進步,只有和同學多交流

溫馨提示

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

評論

0/150

提交評論