圖的基本操作與實現(xiàn)的課程設計報告_第1頁
已閱讀1頁,還剩25頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  《軟件認知實踐》報告</p><p>  姓 名: 學 號: </p><p>  專 業(yè): </p><p>  設計題目: </p><p>  指導教師: </p><p&g

2、t;  2013年12月30日</p><p><b>  目 錄</b></p><p>  第1章 題目概述2</p><p>  第1.1節(jié) 題目要求2</p><p>  第1.2節(jié) 主要難點3</p><p>  第2章 系統(tǒng)流程圖4</p><p&g

3、t;  第3章 數(shù)據(jù)結構和算法5</p><p>  第4章 核心代碼分析6</p><p>  第5章 復雜度分析25</p><p><b>  參考文獻25</b></p><p><b>  題目概述</b></p><p>  第1.1節(jié) 題目要求</

4、p><p>  (1)自選存儲結構,輸入含n個頂點(用字符表示頂點)和e條邊的圖G;</p><p>  (2)求每個頂點的度,輸出結果;</p><p>  (3)指定任意頂點x為初始頂點,對圖G作DFS遍歷,輸出DFS頂點序列(提示:使用一個棧實現(xiàn)DFS);</p><p>  (4)指定任意頂點x為初始頂點,對圖G作BFS遍歷,輸出BFS頂

5、點序列(提示:使用一個隊列實現(xiàn)BFS);</p><p>  (5)輸入頂點x,查找圖G:若存在含x的頂點,則刪除該結點及與之相關連的邊,并作DFS遍歷(執(zhí)行操作3);否則輸出信 息“無x”;</p><p>  (6)判斷圖G是否是連通圖,輸出信息“YES”/“NO”;</p><p>  (7)如果選用的存儲結構是鄰接矩陣,則用鄰接矩陣的信息生成圖G的鄰接表,即

6、復制圖G,然再執(zhí)行操作(2);反之亦然。</p><p>  第1.2節(jié) 主要難點</p><p>  (1)自選存儲結構創(chuàng)建一個圖:通過用戶從鍵盤敲入的兩個數(shù)值分別確定圖的頂點數(shù)和邊數(shù),選擇鄰接矩陣存儲結構將圖的結點信息存儲在一個順序表中,圖的邊信息存儲在一個二維數(shù)組中。</p><p>  (2)求每個頂點的度:</p><p>  1.

7、鄰接矩陣存儲結構下求每個頂點的度:利用圖的鄰接矩陣,每個頂點所在行和所在列的邊的權值如果存在則該頂點的度+1,依次算出每個頂點的度,并且記錄在一個數(shù)組中輸出。</p><p>  2.鄰接表存儲結構下求每個頂點的度:定義一個鄰接邊指針循環(huán)指向頂點的鄰接邊單鏈表頭結點,當結點不空時,該頂點的出度+1,鄰接邊弧頭結點的入度+1,依次求出每個頂點的出度和入度之和就為該頂點的度。</p><p>

8、  (3)圖的深度優(yōu)先遍歷:采取鄰接矩陣結構,指定任意頂點x為初始頂點</p><p>  1.訪問結點v并標記結點v已訪問;</p><p>  2.查找結點v的第一個鄰接結點w;</p><p>  3.若結點v的鄰接結點w存在,則繼續(xù)執(zhí)行,否則算法結束;</p><p>  4.若結點w尚未被訪問,則遞歸訪問結點w;</p>

9、<p>  5.查找結點v的w鄰接結點的下一個鄰接結點w,轉到步驟3。</p><p>  (4)圖的廣度優(yōu)先遍歷:采取鄰接矩陣結構,指定任意頂點x為初始頂點,利用順序循環(huán)隊列以保持訪問過的結點的順序</p><p>  1.首先訪問初始結點v并標記結點v為已訪問;</p><p><b>  2.結點v入隊列;</b></

10、p><p>  3.當隊列非空時則繼續(xù)執(zhí)行,否則算法結束;</p><p>  4.出隊列取得隊頭結點u;</p><p>  5.查找u的第一個鄰接結點w;</p><p>  6.若u的鄰接結點w不存在則轉到步驟3,否則循環(huán)執(zhí)行下列步驟:</p><p>  6.1若結點w尚未被訪問,則訪問結點w并標記結點w為已訪問;

11、</p><p>  6.2結點w入隊列;</p><p>  6.3查找結點u的w鄰接結點的下一個鄰接結點w,轉到步驟6 。</p><p>  (5)判斷有向圖的強連通性:采取鄰接表結構,在圖中尋找一個包含所有頂點且首尾相連的環(huán),若這樣的環(huán)存在,則該圖為強連通圖,否則不為強連通圖。</p><p>  (6)用鄰接矩陣的信息生成鄰接表:定

12、義一個鄰接表的邊信息結構體,將鄰接矩陣的邊信息轉換成鄰接表的邊信息存儲到鄰接邊的單鏈表中。</p><p><b>  第二章 系統(tǒng)流程圖</b></p><p><b>  數(shù)據(jù)結構和算法</b></p><p>  (1)有向圖頂點的數(shù)據(jù)類型DataType 定義如下:</p><p>  ty

13、pedef int DataType ;</p><p>  (2)鄰接矩陣存儲結構下圖的結構體定義如下:</p><p>  typedef struct</p><p><b>  {</b></p><p>  SeqList Vertices; </p><p>  int edge[Ma

14、xVertices][MaxVertices];</p><p>  int numOfEdges; </p><p>  }AdjMGraph; </p><p>  (3)鄰接矩陣存儲結構下圖的邊信息結構體定義如下:</p><p>  typedef struct</p><p><b>  {<

15、;/b></p><p><b>  int row; </b></p><p><b>  int col; </b></p><p>  int weight; </p><p>  }RowColWeight; </p><p>  (4)鄰接表存儲結構下圖的

16、結構體定義如下:</p><p>  typedef struct Node </p><p><b>  {</b></p><p>  int dest; </p><p>  struct Node *next; </p><p><b>  }Edge; </b>

17、;</p><p>  typedef struct</p><p><b>  {</b></p><p>  DataType data; </p><p>  int sorce; </p><p>  Edge *adj; </p><p>  }AdjLH

18、eight; </p><p>  typedef struct</p><p><b>  {</b></p><p>  AdjLHeight a[MaxVertices]; </p><p>  int numOfVerts; </p><p>  int numOfEdges; &l

19、t;/p><p>  }AdjLGraph; </p><p>  (5)鄰接表存儲結構下圖的邊信息結構體定義如下:</p><p>  typedef struct</p><p><b>  {</b></p><p>  int row; </p><p>  int

20、 col; </p><p>  }RowCol; </p><p>  (6)順序循環(huán)隊列的結構體定義如下:</p><p>  typedef struct </p><p><b>  {</b></p><p>  DataType queue[MaxQueueSize];</p

21、><p><b>  int rear;</b></p><p>  int front;</p><p>  int count;</p><p>  }SeqCQueue;</p><p>  (7)順序表的結構體定義如下:</p><p>  typedef struct

22、</p><p><b>  {</b></p><p>  DataType list[MaxSize];</p><p><b>  int size;</b></p><p><b>  }SeqList;</b></p><p>  第四章 核心

23、代碼分析</p><p>  源程序存放在八個文件夾中,文件SeqList.h是順序表的結構體定義和操作函數(shù),文件SeqCQueue.h是順序循環(huán)隊列的結構體定義和操作函數(shù),文件AdjMGraph.h是鄰接矩陣存儲結構下圖的結構體定義和操作函數(shù),文件AdjMGraphCreate.h是鄰接矩陣存儲結構下圖的創(chuàng)建函數(shù),文件AdjLGraph.h是鄰接表存儲結構下圖的結構體定義和操作函數(shù),文件AdjLGraphCre

24、ate.h是鄰接表存儲結構下圖的創(chuàng)建函數(shù),文件AdjMGraphTraverse.h是鄰接矩陣存儲結構下圖的深度優(yōu)先遍歷和廣度優(yōu)先遍歷操作函數(shù),文件圖的基本操作與實現(xiàn).c是主函數(shù)。</p><p>  (1)/* 文件SeqList.h */</p><p>  typedef struct</p><p><b>  {</b></p&

25、gt;<p>  DataType list[MaxSize];</p><p><b>  int size;</b></p><p><b>  }SeqList;</b></p><p>  void ListInitiate(SeqList *L)</p><p><b&

26、gt;  {</b></p><p>  L->size=0;</p><p><b>  }</b></p><p>  int ListLength(SeqList L)</p><p><b>  {</b></p><p>  return L.si

27、ze;</p><p><b>  }</b></p><p>  int ListInsert(SeqList *L,int i,DataType x)</p><p><b>  {</b></p><p><b>  int j;</b></p><p

28、>  if(L->size>=MaxSize)</p><p><b>  {</b></p><p>  printf("數(shù)組已滿無法插入!\n");</p><p><b>  return 0;</b></p><p><b>  }</b

29、></p><p>  else if(i<0||i>L->size)</p><p><b>  {</b></p><p>  printf("參數(shù)不合法!\n");</p><p><b>  return 0;</b></p><

30、;p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  for(j=L->size;j>i;i--)L->list[j]=L->list[j-1];</p><p> 

31、 L->list[i]=x;</p><p>  L->size++;</p><p><b>  return 1;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  int Lis

32、tDelete(SeqList *L,int i,DataType *x)</p><p><b>  {</b></p><p><b>  int j;</b></p><p>  if(L->size<=0)</p><p><b>  {</b></p

33、><p>  printf("順序表已空無數(shù)據(jù)元素可刪!\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  else if(i<0||i>L->size-1)</p><

34、p><b>  {</b></p><p>  printf("參數(shù)i不合法!\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p><b>  else</b>

35、</p><p><b>  {</b></p><p>  *x=L->list[i];</p><p>  for(j=i+1;j<=L->size-1;j++)L->list[j-1]=L->list[j];</p><p>  L->size--;</p><

36、;p><b>  return 1;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  int ListGet(SeqList L,int i,DataType *x)</p><p><b>  {&l

37、t;/b></p><p>  if(i<0||i>L.size-1)</p><p><b>  {</b></p><p>  printf("參數(shù)i不合法!\n");</p><p><b>  return 0;</b></p><p

38、><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  *x=L.list[i];</p><p><b>  return 1;</b></p><p&

39、gt;<b>  }</b></p><p><b>  }</b></p><p>  (2)/* 文件SeqCQueue.h */</p><p>  typedef struct </p><p><b>  {</b></p><p>  Dat

40、aType queue[MaxQueueSize];</p><p><b>  int rear;</b></p><p>  int front;</p><p>  int count;</p><p>  }SeqCQueue;</p><p>  void QueueInitiate(S

41、eqCQueue *Q)</p><p><b>  {</b></p><p>  Q->rear=0;</p><p>  Q->front =0;</p><p>  Q->count =0;</p><p><b>  }</b></p>

42、<p>  int QueueNotEmpty(SeqCQueue Q)</p><p><b>  {</b></p><p>  if(Q.count !=0) return 1;</p><p>  else return 0;</p><p><b>  }</b></

43、p><p>  int QueueAppend(SeqCQueue *Q,DataType x)</p><p><b>  {</b></p><p>  if(Q->count>0&&Q->rear==Q->front)</p><p><b>  {</b>

44、</p><p>  printf("隊列已滿無法插入!");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p><b>  else </b></p><p><b

45、>  {</b></p><p>  Q->queue [Q->rear]=x;</p><p>  Q->rear =(Q->rear +1)%MaxQueueSize;</p><p>  Q->count ++;</p><p><b>  return 1;</b>

46、</p><p><b>  }</b></p><p><b>  }</b></p><p>  int QueueDelete(SeqCQueue *Q,DataType *d)</p><p><b>  {</b></p><p>  if(Q

47、->count ==0)</p><p><b>  {</b></p><p>  printf("隊列已空無數(shù)據(jù)出隊列!\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p>

48、<p><b>  else</b></p><p><b>  {</b></p><p>  *d=Q->queue[Q->front];</p><p>  Q->front=(Q->front+1)%MaxQueueSize;</p><p>  Q-&g

49、t;count --;</p><p><b>  return 1;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  int QueueGet(SeqCQueue Q,DataType*d)</p>&

50、lt;p><b>  {</b></p><p>  if(Q.count ==0)</p><p><b>  {</b></p><p>  printf("隊列已空無數(shù)據(jù)出隊列!\n");</p><p><b>  return 0;</b>&

51、lt;/p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  *d=Q.queue [Q.front ];</p><p><b>  return 1;<

52、;/b></p><p><b>  }</b></p><p><b>  }</b></p><p>  (3)/* 文件AdjMGraph.h*/</p><p>  #include"SeqList.h"</p><p>  typedef

53、struct</p><p><b>  {</b></p><p>  SeqList Vertices; //存放結點的順序表</p><p>  int edge[MaxVertices][MaxVertices]; //存放邊的鄰接矩陣</p><p>  int numOfEdges; //邊的條數(shù)<

54、;/p><p>  }AdjMGraph; //邊的結構體定義</p><p>  void Initiate(AdjMGraph *G,int n) //初始化</p><p><b>  {</b></p><p><b>  int i,j;</b></p><p>

55、  for(i=0;i<n;i++)</p><p>  for(j=0;j<n;j++)</p><p><b>  {</b></p><p><b>  if(i==j)</b></p><p>  G->edge[i][j]=0;</p><p>&

56、lt;b>  else</b></p><p>  G->edge[i][j]=MaxWeight;</p><p><b>  }</b></p><p>  G->numOfEdges=0; //邊的條數(shù)置為0</p><p>  ListInitiate(&G->V

57、ertices); //順序表初始化</p><p><b>  }</b></p><p>  void InsertVertex(AdjMGraph *G,DataType vertex) //在圖G中插入結點vertex</p><p><b>  {</b></p><p>  List

58、Insert(&G->Vertices,G->Vertices.size,vertex); //順序表尾插入</p><p><b>  }</b></p><p>  void InsertEdge(AdjMGraph *G,int v1,int v2,int weight)</p><p>  //在圖G中插入邊<

59、;v1,v2>,邊<v1,v2>的權為weight</p><p><b>  {</b></p><p>  if(v1<0||v1>G->Vertices.size||v2<0||v2>G->Vertices.size)</p><p><b>  {</b><

60、;/p><p>  printf("參數(shù)v1或v2越界出錯!\n");</p><p><b>  exit(1);</b></p><p><b>  }</b></p><p>  G->edge[v1][v2]=weight;</p><p>  

61、G->numOfEdges++;</p><p><b>  }</b></p><p>  void DeleteEdge(AdjMGraph *G,int v1,int v2) //在圖中刪除邊<v1,v2></p><p><b>  {</b></p><p>  if(

62、v1<0||v1>G->Vertices.size||v2<0||v2>G->Vertices.size||v1==v2)</p><p><b>  {</b></p><p>  printf("參數(shù)v1或v2越界出錯!\n");</p><p><b>  exit(1);

63、</b></p><p><b>  }</b></p><p>  if(G->edge[v1][v2]==MaxWeight||v1==v2)</p><p><b>  {</b></p><p>  printf("該邊不存在!\n");</p&g

64、t;<p><b>  exit(0);</b></p><p><b>  }</b></p><p>  G->edge[v1][v2]=MaxWeight;</p><p>  G->numOfEdges--;</p><p><b>  }</b&g

65、t;</p><p>  void DeleteVerten(AdjMGraph *G,int v) //刪除結點v</p><p><b>  {</b></p><p>  int n=ListLength(G->Vertices),i,j; </p><p>  DataType x;</p>

66、<p>  for(i=0;i<n;i++) //計算刪除后的邊數(shù)</p><p><b>  {</b></p><p>  for(j=0;j<n;j++)</p><p>  if((i==v||j==v)&&G->edge[i][j]>0&&G->edge[i

67、][j]<MaxWeight)</p><p>  G->numOfEdges--; //計算被刪除邊</p><p><b>  }</b></p><p>  for(i=v;i<n;i++) //刪除第v行</p><p><b>  {</b></p>&

68、lt;p>  for(j=0;j<n;j++)</p><p>  G->edge[i][j]=G->edge[i+1][j];</p><p><b>  }</b></p><p>  for(i=0;i<n;i++) //刪除第v列</p><p><b>  {</

69、b></p><p>  for(j=v;j<n;j++)</p><p>  G->edge[i][j]=G->edge[i][j+1];</p><p><b>  }</b></p><p>  ListDelete(&G->Vertices,v,&x); //刪除結

70、點v</p><p><b>  }</b></p><p>  int GetFistVex(AdjMGraph *G,int v) </p><p>  //在圖G中尋找序號為v的結點的第一個鄰接結點</p><p>  //如果這樣的鄰接結點存在,返回該鄰接結點的序號;否則,返回-1</p><

71、;p><b>  {</b></p><p><b>  int col;</b></p><p>  if(v<0||v>G->Vertices.size)</p><p><b>  {</b></p><p>  printf("參數(shù)v1

72、越界出錯!\n");</p><p><b>  exit(1);</b></p><p><b>  }</b></p><p>  for(col=0;col<G->Vertices.size;col++)</p><p>  if(G->edge[v][col]&g

73、t;0&&G->edge[v][col]<MaxWeight)return col;</p><p>  return -1;</p><p><b>  }</b></p><p>  int GetNextVex(AdjMGraph*G,int v1,int v2)</p><p>  /

74、/在圖中尋找v1結點的鄰接結點v2的下一個鄰接結點</p><p>  //如果這樣的結點存在,返回該鄰接結點的序號;否則,返回-1</p><p>  //v1和v2都是相應結點的序號</p><p><b>  {</b></p><p><b>  int col;</b></p>

75、<p>  if(v1<0||v1>G->Vertices.size||v2<0||v2>G->Vertices.size)</p><p><b>  {</b></p><p>  printf("參數(shù)v1或v2越界出錯!\n");</p><p>  exit(1);

76、 </p><p><b>  }</b></p><p>  for(col=v2+1;col<G->Vertices.size;col++)</p><p>  if(G->edge[v1][col]>0&&G->edge[v1][col]<MaxWeight)return col;&

77、lt;/p><p>  return -1;</p><p><b>  }</b></p><p>  //輸出圖G的鄰接矩陣</p><p>  void Print(AdjMGraph *G) </p><p><b>  {</b></p><p&g

78、t;<b>  int i,j;</b></p><p>  for(i=0;i<G->Vertices.size;i++)</p><p><b>  {</b></p><p>  for(j=0;j<G->Vertices.size;j++)</p><p>  pri

79、ntf("%6d ",G->edge[i][j]);</p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  //鄰接矩陣存儲結構下求出每個頂點的度并輸出<

80、/p><p>  void MVertices(AdjMGraph *G,DataType a[]) </p><p><b>  {</b></p><p>  int i,j,m;</p><p>  DataType b[MaxVertices];//用數(shù)組b[]記錄相應結點的度</p><p&g

81、t;  for(i=0;i<G->Vertices.size;i++)</p><p>  b[i]=0; //置0</p><p>  printf("鄰接矩陣存儲結構下圖的頂點的度為:\n");</p><p>  for(m=0;m<G->Vertices.size;m++) //求出每個結點的度</p&g

82、t;<p><b>  {</b></p><p>  for(i=0;i<G->Vertices.size;i++)</p><p>  for(j=0;j<G->Vertices.size;j++)</p><p><b>  {</b></p><p> 

83、 if(i==m&&G->edge[i][j]>0&&G->edge[i][j]<MaxWeight)</p><p>  //求出鄰接矩陣第i行權值存在的邊的個數(shù),當邊<m,j>存在時,b[m]加1</p><p><b>  b[m]++;</b></p><p>  if

84、(j==m&&i!=m&&G->edge[i][j]>0&&G->edge[i][j]<MaxWeight)</p><p>  //求出鄰接矩陣第j列權值存在的邊的個數(shù),當邊<i,m>存在時,b[m]加1</p><p><b>  b[m]++;</b></p>&l

85、t;p><b>  }</b></p><p>  printf("頂點%d的度為:%d\n",a[m],b[m]);</p><p><b>  }</b></p><p><b>  }</b></p><p>  //查找圖G中是否存在點v<

86、;/p><p>  int ChaZhao(AdjMGraph *G,int v) </p><p><b>  {</b></p><p>  if(0<=v&&v<G->Vertices.size)</p><p><b>  {</b></p>&

87、lt;p>  printf("存在頂點%d\n",v);</p><p><b>  return 1;</b></p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b

88、></p><p>  printf("不存在頂點%d\n",v);</p><p><b>  return 0;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  /

89、/刪除查找到的結點v并刪除該結點及與之相關的邊</p><p>  void MDelete(AdjMGraph *G,int v)</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  for(i=0;i<G->Vertices.

90、size;i++)</p><p><b>  {</b></p><p>  if(G->edge[v][i]>0&&G->edge[v][i]<MaxWeight)</p><p>  //當鄰接矩陣的第v行有邊<v,i>存在時,刪除邊<v,i></p><

91、p>  DeleteEdge(G,v,i);</p><p>  if(G->edge[i][v]>0&&G->edge[i][v]<MaxWeight)</p><p>  //當鄰接矩陣的第j行有邊<i,v>存在時,刪除邊<i,v></p><p>  DeleteEdge(G,i,v);&l

92、t;/p><p><b>  }</b></p><p>  DeleteVerten(G,v);//刪除結點v</p><p><b>  }</b></p><p>  (4)/* 文件AdjMGraphCreate.h */</p><p>  typedef struct

93、</p><p><b>  {</b></p><p>  int row; //行下標</p><p>  int col; //列下標</p><p>  int weight; //權值</p><p>  }RowColWeight; //邊信息結構體定義</p>

94、<p>  void CreatGraph(AdjMGraph *G,DataType v[],int n,RowColWeight E[],int e)</p><p>  //在圖G中插入n個結點信息v和e條邊信息E</p><p><b>  {</b></p><p><b>  int i,k;</b>

95、</p><p>  Initiate(G,n); //結點順序表初始化</p><p>  for(i=0;i<n;i++)</p><p>  InsertVertex(G,v[i]); //結點插入</p><p>  for(k=0;k<e;k++)</p><p>  InsertEdge(G

96、,E[k].row,E[k].col,E[k].weight); //邊插入</p><p><b>  }</b></p><p>  (5)/* 文件AdjLGraph.h */</p><p>  //鄰接表的存儲結構</p><p>  typedef struct Node </p><

97、p><b>  {</b></p><p>  int dest; //鄰接邊的弧頭結點序號</p><p>  struct Node *next; </p><p>  }Edge; //鄰接邊單鏈表的結點結構體</p><p>  typedef struct</p><p>&

98、lt;b>  {</b></p><p>  DataType data; //結點數(shù)據(jù)元素 </p><p>  int sorce; //鄰接邊的弧尾結點序號</p><p>  Edge *adj; //鄰接邊的頭指針</p><p>  }AdjLHeight; //數(shù)組的數(shù)據(jù)元素類型結構體</p>

99、;<p>  typedef struct</p><p><b>  {</b></p><p>  AdjLHeight a[MaxVertices]; //鄰接表數(shù)組</p><p>  int numOfVerts; //結點個數(shù)</p><p>  int numOfEdges; //邊個數(shù)

100、</p><p>  }AdjLGraph; //鄰接表結構體</p><p><b>  //初始化操作函數(shù)</b></p><p>  void LAdjInitiate(AdjLGraph *G)</p><p><b>  {</b></p><p><b&g

101、t;  int i;</b></p><p>  G->numOfVerts=0;</p><p>  G->numOfEdges=0;</p><p>  for(i=0;i<MaxVertices;i++)</p><p><b>  {</b></p><p>

102、  G->a[i].sorce=i;</p><p>  G->a[i].adj=NULL;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  //撤銷操作函數(shù)</b></p><p>

103、;  void LAdjDestroy(AdjLGraph *G)</p><p>  //撤銷圖G中的所有鄰接邊單鏈表</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  Edge *p,*q;</p><p>  

104、for(i=0;i<G->numOfVerts;i++)</p><p><b>  {</b></p><p>  p=G->a[i].adj;</p><p>  while(p!=NULL)</p><p><b>  {</b></p><p>  

105、q=p->next;</p><p><b>  free(p);</b></p><p><b>  p=q;</b></p><p><b>  }</b></p><p><b>  }</b></p><p><

106、b>  }</b></p><p>  //插入結點操作函數(shù)</p><p>  void LInsertVertex(AdjLGraph *G,int i,DataType vertex)</p><p>  //在圖G中的第i(0<=i<MaxVertices)個位置插入結點數(shù)據(jù)元素vertex</p><p&g

107、t;<b>  {</b></p><p>  if(i>=0&&i<MaxVertices)</p><p><b>  {</b></p><p>  G->a[i].data=vertex; //存儲結點數(shù)據(jù)元素vertex</p><p>  G->

108、numOfVerts++; //個數(shù)加1</p><p><b>  }</b></p><p><b>  else</b></p><p>  printf("結點越界");</p><p><b>  }</b></p><

109、;p><b>  //插入邊操作函數(shù)</b></p><p>  void LInsertEdge(AdjLGraph *G,int v1,int v2)</p><p>  //在圖G中加入邊<v1,v2>的信息</p><p><b>  {</b></p><p>  Edg

110、e *p; //定義一個鄰接邊指針</p><p>  if(v1<0||v1>=G->numOfVerts||v2<0||v2>=G->numOfVerts)</p><p><b>  {</b></p><p>  printf("參數(shù)v1或v2越界出錯");</p>

111、<p><b>  exit(0);</b></p><p><b>  }</b></p><p>  p=(Edge *)malloc(sizeof(Edge)); //申請鄰接邊單鏈表結點空間</p><p>  p->dest=v2; //置鄰接邊弧頭序號</p><p&g

112、t;  p->next=G->a[v1].adj; //新結點插入單鏈表的表頭</p><p>  G->a[v1].adj=p; //頭指針指向新的單鏈表表頭</p><p>  G->numOfEdges++; //邊數(shù)個數(shù)加1</p><p><b>  } </b></p><p>

113、<b>  //刪除邊操作函數(shù)</b></p><p>  void LDeleteEdge(AdjLGraph *G,int v1,int v2)</p><p>  //刪除圖G中的邊<v1,v2>信息</p><p><b>  {</b></p><p>  Edge *curr

114、,*pre;</p><p>  if(v1<0||v1>=G->numOfVerts||v2<0||v2>=G->numOfVerts)</p><p><b>  {</b></p><p>  printf("參數(shù)v1或v2越界出錯!");</p><p>&

115、lt;b>  exit(0);</b></p><p><b>  }</b></p><p><b>  pre=NULL;</b></p><p>  curr=G->a[v1].adj;</p><p>  while(curr!=NULL&&curr-

116、>dest!=v2)</p><p>  //在v1結點的鄰接邊單鏈表中查找v2結點</p><p><b>  {</b></p><p><b>  pre=curr;</b></p><p>  curr=curr->next;</p><p><b&

117、gt;  }</b></p><p>  //刪除表示鄰接邊<v1,v2>的結點</p><p>  if(curr!=NULL&&curr->dest==v2&&pre==NULL)</p><p>  //當鄰接邊<v1,v2>的結點是單鏈表的第一個結點時</p><p

118、><b>  {</b></p><p>  G->a[v1].adj=curr->next;</p><p>  free(curr);</p><p>  G->numOfEdges--;</p><p><b>  }</b></p><p> 

119、 else if(curr!=NULL&&curr->dest==v2&&pre!=NULL)</p><p>  //當鄰接邊<v1,v2>的結點不是單鏈表的第一個結點時</p><p><b>  {</b></p><p>  pre->next=curr->next;<

120、;/p><p>  free(curr);</p><p>  G->numOfEdges--;</p><p><b>  }</b></p><p><b>  else</b></p><p>  //當鄰接邊<v1,v2>結點不存在時</p>

121、<p>  printf("邊<v1,v2>不存在時");</p><p><b>  }</b></p><p>  //取第一個鄰接結點</p><p>  int LGetFirstVex(AdjLGraph *G,int v)</p><p>  //取圖G中結點v的

122、第一個鄰接結點</p><p>  //取到時返回該鄰接結點的對應序號,否則返回-1</p><p><b>  {</b></p><p><b>  Edge *p;</b></p><p>  if(v<0||v>G->numOfVerts)</p><p

123、><b>  {</b></p><p>  printf("參數(shù)v1或v2越界出錯!");</p><p><b>  exit(0);</b></p><p><b>  }</b></p><p>  p=G->a[v].adj;</

124、p><p>  if(p!=NULL)</p><p>  return p->dest; //返回該鄰接結點的對應序號</p><p><b>  else</b></p><p>  return -1; //返回-1</p><p><b>  }</b><

125、/p><p>  //取下一個鄰接結點</p><p>  int LGetNextVex(AdjLGraph *G,int v1,int v2)</p><p>  //取圖G中結點v1的鄰接結點v2的下一個鄰接結點</p><p>  //取到時返回該鄰接結點的對應序號,否則返回-1</p><p><b>

126、  {</b></p><p><b>  Edge *p;</b></p><p>  if(v1<0||v1>G->numOfVerts||v2<0||v2>G->numOfVerts)</p><p><b>  {</b></p><p>  

127、printf("參數(shù)v1或v2越界出錯!");</p><p><b>  exit(0);</b></p><p><b>  }</b></p><p>  p=G->a[v1].adj;</p><p>  while(p!=NULL) //尋找結點v1的鄰接結點v

128、2</p><p><b>  {</b></p><p>  if(p->dest!=v2)</p><p><b>  {</b></p><p>  p=p->next;</p><p><b>  continue;</b></

129、p><p><b>  }</b></p><p><b>  else</b></p><p><b>  break;</b></p><p><b>  }</b></p><p>  p=p->next; //p指向鄰接

130、結點v2的下一個鄰接結點</p><p>  if(p!=NULL)</p><p>  return p->dest; //返回該鄰接結點的對應序號</p><p><b>  else</b></p><p>  return -1; //返回-1</p><p><b>

131、  }</b></p><p>  //鄰接表存儲下求每個頂點的度并輸出結果</p><p>  void LVertices(AdjLGraph *G,DataType a[])</p><p><b>  {</b></p><p>  printf("鄰接表存儲結構下的圖的頂點的度為:\n&q

132、uot;);</p><p>  int OutDegree[MaxVertices],InDegree[MaxVertices];//定義一個出度和入度的數(shù)組</p><p><b>  int i;</b></p><p>  for(i=0;i<G->numOfVerts;i++) //首先將出度和入度數(shù)組的每個成員都置0&

133、lt;/p><p><b>  {</b></p><p>  OutDegree[i]=0;</p><p>  InDegree[i]=0;</p><p><b>  }</b></p><p>  Edge *p; //定義一個鄰接邊指針</p><

134、p>  for(i=0;i<G->numOfVerts;i++)</p><p><b>  {</b></p><p>  p=G->a[i].adj; //指針指向a[i]的鄰接邊單鏈表頭結點</p><p>  while(p!=NULL)//當p所指向的鄰接邊結點不空時</p><p>

135、<b>  {</b></p><p>  OutDegree[i]++; //出度加1</p><p>  InDegree[p->dest]++; //鄰接邊弧頭結點的入度加1</p><p>  p=p->next; //p指向下一個鄰接邊結點</p><p><b>  }</b>

136、;</p><p><b>  }</b></p><p>  for(i=0;i<G->numOfVerts;i++) //輸出每個結點的度</p><p><b>  {</b></p><p>  printf("頂點%d的度為:",a[i]);</p&g

137、t;<p>  printf("%d",OutDegree[i]+InDegree[i]); //每個結點的度即出度與入度相加的和</p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  }</b></p

138、><p>  //判斷有向圖G是否為強連通圖</p><p>  int LianTong(AdjLGraph *G,DataType a[]) </p><p><b>  {</b></p><p>  int i,b[MaxVertices],k=0;</p><p>  for(i=0;i&l

139、t;G->numOfVerts;i++)</p><p><b>  b[i]=0;</b></p><p>  Edge *q,*p; //定義一個鄰接邊指針</p><p>  for(i=0;i<G->numOfVerts;i++)</p><p><b>  {</b>&

140、lt;/p><p>  q=G->a[i].adj;</p><p>  while(q!=NULL)</p><p><b>  {</b></p><p><b>  b[i]++;</b></p><p>  q=q->next;</p><

141、p><b>  }</b></p><p><b>  }</b></p><p>  for(i=0;i<G->numOfVerts;i++)</p><p><b>  {</b></p><p>  if(b[i]==1)</p><

142、p><b>  k++;</b></p><p><b>  }</b></p><p>  p=G->a[G->numOfVerts-1].adj;</p><p>  if(k==G->numOfVerts&&p->dest==a[0])</p><p&

143、gt;<b>  return 1;</b></p><p><b>  else</b></p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  (6)/* 文件AdjLGraphCreate.

144、h */</p><p>  typedef struct</p><p><b>  {</b></p><p>  int row; //行下標</p><p>  int col; //列下標</p><p>  }RowCol; //邊信息結構體定義</p><p

145、>  void CreatLGraph(AdjLGraph *G,DataType v[],int n,RowCol d[],int e)</p><p><b>  {</b></p><p><b>  int i,k;</b></p><p>  LAdjInitiate(G);</p><

146、p>  for(i=0;i<n;i++)</p><p>  LInsertVertex(G,i,v[i]);</p><p>  for(k=0;k<e;k++)</p><p>  LInsertEdge(G,d[k].row,d[k].col);</p><p><b>  }</b></p

147、><p>  (7)/* 文件AdjMGraphTraverse.h */</p><p>  void Visit(DataType item)</p><p><b>  {</b></p><p>  printf("%d ",item);</p><p><b>

148、  }</b></p><p>  void DepthFSearch(AdjMGraph G,int v,int visited[],void Visit(DataType item))</p><p>  //連通圖G以v為初始結點的訪問操作為Visit()的深度優(yōu)先遍歷</p><p>  //數(shù)組visited標記了相應結點是否已訪問過,0表示未

149、訪問,1表示已訪問</p><p><b>  {</b></p><p><b>  int w;</b></p><p>  Visit(G.Vertices.list[v]); //訪問結點v</p><p>  visited[v]=1; //置已訪問標記</p><

溫馨提示

  • 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論