版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)</b></p><p><b> 課程設(shè)計報告</b></p><p> 設(shè)計題目: 圖的基本操作與實現(xiàn)</p><p> 專 業(yè) </p><p> 班 級 </p><p> 學(xué)
2、 生 </p><p> 學(xué) 號 </p><p> 指導(dǎo)教師 </p><p> 起止時間 </p><p><b> 年 學(xué)期</b></p><p><b> 目
3、錄</b></p><p> 1.問題描述:實現(xiàn)圖的一些基本操作3</p><p><b> 2.基本要求:3</b></p><p> (2)求每個頂點的度,輸出結(jié)果;3</p><p><b> 3.測試數(shù)據(jù):3</b></p><p><
4、;b> 4.算法思想:3</b></p><p> (1)自選存儲結(jié)構(gòu)創(chuàng)建一個圖:3</p><p> (2)求每個頂點的度:3</p><p> (3)圖的深度優(yōu)先遍歷:4</p><p> (4)圖的廣度優(yōu)先遍歷:4</p><p> (5)判斷有向圖的強(qiáng)連通性:4<
5、/p><p> (6)用鄰接矩陣的信息生成鄰接表:4</p><p><b> 6.數(shù)據(jù)結(jié)構(gòu):5</b></p><p><b> 7.功能模塊圖7</b></p><p><b> 8.源程序:8</b></p><p> 9.心得體會:
6、28</p><p> 1.問題描述:實現(xiàn)圖的一些基本操作</p><p><b> 2.基本要求:</b></p><p> (1)自選存儲結(jié)構(gòu),輸入含n個頂點(用字符表示頂點)和e條邊的圖G;</p><p> (2)求每個頂點的度,輸出結(jié)果;</p><p> (3)指定任意頂點
7、x為初始頂點,對圖G作DFS遍歷,輸出DFS頂點序列(提示:使用一個棧實現(xiàn)DFS);</p><p> (4)指定任意頂點x為初始頂點,對圖G作BFS遍歷,輸出BFS頂點序列(提示:使用一個隊列實現(xiàn)BFS);</p><p> (5)輸入頂點x,查找圖G:若存在含x的頂點,則刪除該結(jié)點及與之相關(guān)連的邊,并作DFS遍歷(執(zhí)行操作3);否則輸出信 息“無x”;</p><
8、;p> (6)判斷圖G是否是連通圖,輸出信息“YES”/“NO”;</p><p> (7)如果選用的存儲結(jié)構(gòu)是鄰接矩陣,則用鄰接矩陣的信息生成圖G的鄰接表,即復(fù)制圖G,然再執(zhí)行操作(2);反之亦然。</p><p><b> 3.測試數(shù)據(jù):</b></p><p> 有向圖的頂點數(shù)n和有向圖的邊數(shù)e由用戶從鍵盤敲入</p&
9、gt;<p><b> 4.算法思想:</b></p><p> (1)自選存儲結(jié)構(gòu)創(chuàng)建一個圖:通過用戶從鍵盤敲入的兩個數(shù)值分別確定圖的頂點數(shù)和邊數(shù),選擇鄰接矩陣存儲結(jié)構(gòu)將圖的結(jié)點信息存儲在一個順序表中,圖的邊信息存儲在一個二維數(shù)組中。</p><p> (2)求每個頂點的度:</p><p> 1.鄰接矩陣存儲結(jié)構(gòu)下求每
10、個頂點的度:利用圖的鄰接矩陣,每個頂點所在行和所在列的邊的權(quán)值如果存在則該頂點的度+1,依次算出每個頂點的度,并且記錄在一個數(shù)組中輸出。</p><p> 2.鄰接表存儲結(jié)構(gòu)下求每個頂點的度:定義一個鄰接邊指針循環(huán)指向頂點的鄰接邊單鏈表頭結(jié)點,當(dāng)結(jié)點不空時,該頂點的出度+1,鄰接邊弧頭結(jié)點的入度+1,依次求出每個頂點的出度和入度之和就為該頂點的度。</p><p> (3)圖的深度優(yōu)先
11、遍歷:采取鄰接矩陣結(jié)構(gòu),指定任意頂點x為初始頂點</p><p> 1.訪問結(jié)點v并標(biāo)記結(jié)點v已訪問;</p><p> 2.查找結(jié)點v的第一個鄰接結(jié)點w;</p><p> 3.若結(jié)點v的鄰接結(jié)點w存在,則繼續(xù)執(zhí)行,否則算法結(jié)束;</p><p> 4.若結(jié)點w尚未被訪問,則遞歸訪問結(jié)點w;</p><p>
12、 5.查找結(jié)點v的w鄰接結(jié)點的下一個鄰接結(jié)點w,轉(zhuǎn)到步驟3。</p><p> (4)圖的廣度優(yōu)先遍歷:采取鄰接矩陣結(jié)構(gòu),指定任意頂點x為初始頂點,利用順序循環(huán)隊列以保持訪問過的結(jié)點的順序</p><p> 1.首先訪問初始結(jié)點v并標(biāo)記結(jié)點v為已訪問;</p><p><b> 2.結(jié)點v入隊列;</b></p><
13、p> 3.當(dāng)隊列非空時則繼續(xù)執(zhí)行,否則算法結(jié)束;</p><p> 4.出隊列取得隊頭結(jié)點u;</p><p> 5.查找u的第一個鄰接結(jié)點w;</p><p> 6.若u的鄰接結(jié)點w不存在則轉(zhuǎn)到步驟3,否則循環(huán)執(zhí)行下列步驟:</p><p> 6.1若結(jié)點w尚未被訪問,則訪問結(jié)點w并標(biāo)記結(jié)點w為已訪問;</p>
14、<p> 6.2結(jié)點w入隊列;</p><p> 6.3查找結(jié)點u的w鄰接結(jié)點的下一個鄰接結(jié)點w,轉(zhuǎn)到步驟6 。</p><p> (5)判斷有向圖的強(qiáng)連通性:采取鄰接表結(jié)構(gòu),在圖中尋找一個包含所有頂點且首尾相連的環(huán),若這樣的環(huán)存在,則該圖為強(qiáng)連通圖,否則不為強(qiáng)連通圖。</p><p> (6)用鄰接矩陣的信息生成鄰接表:定義一個鄰接表的邊信息結(jié)
15、構(gòu)體,將鄰接矩陣的邊信息轉(zhuǎn)換成鄰接表的邊信息存儲到鄰接邊的單鏈表中。</p><p><b> 5.模塊劃分:</b></p><p> mian():主函數(shù)模塊。在主函數(shù)模塊中調(diào)用以下函數(shù):</p><p> void CreatGraph(AdjMGraph *G,DataType v[],int n,RowColWeight E[]
16、,int e):創(chuàng)建一個鄰接矩陣存儲結(jié)構(gòu)的圖;</p><p> void Print(AdjMGraph *G):輸出圖的鄰接矩陣;</p><p> void MVertices(AdjMGraph *G,DataType a[]):求出鄰接矩陣存儲結(jié)構(gòu)下圖的每個頂點的度;</p><p> void CreatLGraph(AdjLGraph *G,Da
17、taType v[],int n,RowCol d[],int e):用鄰接矩陣的信息生成鄰接表;</p><p> void LVertices(AdjLGraph *G,DataType a[]):求出鄰接表存儲結(jié)構(gòu)下圖的每個頂點的度;</p><p> int LianTong(AdjLGraph *G,DataType a[]):判斷有向圖的強(qiáng)連通性;</p>&
18、lt;p> void DepthFirstSearch(AdjMGraph G,void Visit(DataType item)):對圖作DFS遍歷,輸出DFS頂點序列;</p><p> void BroadFirstSearch(AdjMGraph G,void Visit(DataType item)):對圖作BFS遍歷,輸出BFS頂點序列;</p><p> int
19、ChaZhao(AdjMGraph *G,int v):查找頂點v;</p><p> void MDelete(AdjMGraph *G,int v):刪除查找到的結(jié)點v并刪除該結(jié)點及與之相關(guān)的邊;</p><p><b> 6.數(shù)據(jù)結(jié)構(gòu):</b></p><p> (1)有向圖頂點的數(shù)據(jù)類型DataType 定義如下:</p&g
20、t;<p> typedef int DataType ;</p><p> (2)鄰接矩陣存儲結(jié)構(gòu)下圖的結(jié)構(gòu)體定義如下:</p><p> typedef struct</p><p><b> {</b></p><p> SeqList Vertices; //存放結(jié)點的順序表</p&
21、gt;<p> int edge[MaxVertices][MaxVertices]; //存放邊的鄰接矩陣</p><p> int numOfEdges; //邊的條數(shù)</p><p> }AdjMGraph; //邊的結(jié)構(gòu)體定義</p><p> (3)鄰接矩陣存儲結(jié)構(gòu)下圖的邊信息結(jié)構(gòu)體定義如下:</p><p&g
22、t; typedef struct</p><p><b> {</b></p><p> int row; //行下標(biāo)</p><p> int col; //列下標(biāo)</p><p> int weight; //權(quán)值</p><p> }RowColWeight; //邊信息結(jié)
23、構(gòu)體定義</p><p> (4)鄰接表存儲結(jié)構(gòu)下圖的結(jié)構(gòu)體定義如下:</p><p> typedef struct Node </p><p><b> {</b></p><p> int dest; //鄰接邊的弧頭結(jié)點序號</p><p> struct Node *nex
24、t; </p><p> }Edge; //鄰接邊單鏈表的結(jié)點結(jié)構(gòu)體</p><p> typedef struct</p><p><b> {</b></p><p> DataType data; //結(jié)點數(shù)據(jù)元素 </p><p> int sorce; //鄰接邊的弧尾結(jié)
25、點序號</p><p> Edge *adj; //鄰接邊的頭指針</p><p> }AdjLHeight; //數(shù)組的數(shù)據(jù)元素類型結(jié)構(gòu)體</p><p> typedef struct</p><p><b> {</b></p><p> AdjLHeight a[MaxVert
26、ices]; //鄰接表數(shù)組</p><p> int numOfVerts; //結(jié)點個數(shù)</p><p> int numOfEdges; //邊個數(shù)</p><p> }AdjLGraph; //鄰接表結(jié)構(gòu)體</p><p> (5)鄰接表存儲結(jié)構(gòu)下圖的邊信息結(jié)構(gòu)體定義如下:</p><p>
27、typedef struct</p><p><b> {</b></p><p> int row; //行下標(biāo)</p><p> int col; //列下標(biāo)</p><p> }RowCol; //邊信息結(jié)構(gòu)體定義</p><p> (6)順序循環(huán)隊列的結(jié)構(gòu)體定義如下:<
28、;/p><p> typedef struct </p><p><b> {</b></p><p> DataType queue[MaxQueueSize];</p><p><b> int rear;</b></p><p> int front;</p
29、><p> int count;</p><p> }SeqCQueue;</p><p> (7)順序表的結(jié)構(gòu)體定義如下:</p><p> typedef struct</p><p><b> {</b></p><p> DataType list[MaxS
30、ize];</p><p><b> int size;</b></p><p><b> }SeqList;</b></p><p><b> 7.功能模塊圖:</b></p><p><b> 8.源程序:</b></p><
31、;p> 源程序存放在八個文件夾中,文件SeqList.h是順序表的結(jié)構(gòu)體定義和操作函數(shù),文件SeqCQueue.h是順序循環(huán)隊列的結(jié)構(gòu)體定義和操作函數(shù),文件AdjMGraph.h是鄰接矩陣存儲結(jié)構(gòu)下圖的結(jié)構(gòu)體定義和操作函數(shù),文件AdjMGraphCreate.h是鄰接矩陣存儲結(jié)構(gòu)下圖的創(chuàng)建函數(shù),文件AdjLGraph.h是鄰接表存儲結(jié)構(gòu)下圖的結(jié)構(gòu)體定義和操作函數(shù),文件AdjLGraphCreate.h是鄰接表存儲結(jié)構(gòu)下圖的創(chuàng)建函
32、數(shù),文件AdjMGraphTraverse.h是鄰接矩陣存儲結(jié)構(gòu)下圖的深度優(yōu)先遍歷和廣度優(yōu)先遍歷操作函數(shù),文件圖的基本操作與實現(xiàn).c是主函數(shù)。</p><p> (1)/* 文件SeqList.h */</p><p> typedef struct</p><p><b> {</b></p><p> Dat
33、aType list[MaxSize];</p><p><b> int size;</b></p><p><b> }SeqList;</b></p><p> void ListInitiate(SeqList *L)</p><p><b> {</b><
34、;/p><p> L->size=0;</p><p><b> }</b></p><p> int ListLength(SeqList L)</p><p><b> {</b></p><p> return L.size;</p><
35、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> if(L->size
36、>=MaxSize)</p><p><b> {</b></p><p> printf("數(shù)組已滿無法插入!\n");</p><p><b> return 0;</b></p><p><b> }</b></p><
37、;p> else if(i<0||i>L->size)</p><p><b> {</b></p><p> printf("參數(shù)不合法!\n");</p><p><b> return 0;</b></p><p><b> }&
38、lt;/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> L->list[i]=x;&l
39、t;/p><p> L->size++;</p><p><b> return 1;</b></p><p><b> }</b></p><p><b> }</b></p><p> int ListDelete(SeqList *L,
40、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><p> pr
41、intf("順序表已空無數(shù)據(jù)元素可刪!\n");</p><p><b> return 0;</b></p><p><b> }</b></p><p> else if(i<0||i>L->size-1)</p><p><b> {&l
42、t;/b></p><p> printf("參數(shù)i不合法!\n");</p><p><b> return 0;</b></p><p><b> }</b></p><p><b> else</b></p><p&g
43、t;<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><p><b> re
44、turn 1;</b></p><p><b> }</b></p><p><b> }</b></p><p> int ListGet(SeqList L,int i,DataType *x)</p><p><b> {</b></p>
45、<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><b> }<
46、;/b></p><p><b> else</b></p><p><b> {</b></p><p> *x=L.list[i];</p><p><b> return 1;</b></p><p><b> }<
47、/b></p><p><b> }</b></p><p> (2)/* 文件SeqCQueue.h */</p><p> typedef struct </p><p><b> {</b></p><p> DataType queue[MaxQueu
48、eSize];</p><p><b> int rear;</b></p><p> int front;</p><p> int count;</p><p> }SeqCQueue;</p><p> void QueueInitiate(SeqCQueue *Q)</p&
49、gt;<p><b> {</b></p><p> Q->rear=0;</p><p> Q->front =0;</p><p> Q->count =0;</p><p><b> }</b></p><p> int Qu
50、eueNotEmpty(SeqCQueue Q)</p><p><b> {</b></p><p> if(Q.count !=0) return 1;</p><p> else return 0;</p><p><b> }</b></p><p> i
51、nt QueueAppend(SeqCQueue *Q,DataType x)</p><p><b> {</b></p><p> if(Q->count>0&&Q->rear==Q->front)</p><p><b> {</b></p><p&g
52、t; printf("隊列已滿無法插入!");</p><p><b> return 0;</b></p><p><b> }</b></p><p><b> else </b></p><p><b> {</b>&l
53、t;/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></p><p&g
54、t;<b> }</b></p><p><b> }</b></p><p> int QueueDelete(SeqCQueue *Q,DataType *d)</p><p><b> {</b></p><p> if(Q->count ==0)<
55、/p><p><b> {</b></p><p> printf("隊列已空無數(shù)據(jù)出隊列!\n");</p><p><b> return 0;</b></p><p><b> }</b></p><p><b>
56、 else</b></p><p><b> {</b></p><p> *d=Q->queue[Q->front];</p><p> Q->front=(Q->front+1)%MaxQueueSize;</p><p> Q->count --;</p&g
57、t;<p><b> return 1;</b></p><p><b> }</b></p><p><b> }</b></p><p> int QueueGet(SeqCQueue Q,DataType*d)</p><p><b>
58、{</b></p><p> if(Q.count ==0)</p><p><b> {</b></p><p> printf("隊列已空無數(shù)據(jù)出隊列!\n");</p><p><b> return 0;</b></p><p>
59、;<b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> *d=Q.queue [Q.front ];</p><p><b> return 1;</b></p>
60、<p><b> }</b></p><p><b> }</b></p><p> (3)/* 文件AdjMGraph.h*/</p><p> #include"SeqList.h"</p><p> typedef struct</p>&
61、lt;p><b> {</b></p><p> SeqList Vertices; //存放結(jié)點的順序表</p><p> int edge[MaxVertices][MaxVertices]; //存放邊的鄰接矩陣</p><p> int numOfEdges; //邊的條數(shù)</p><p>
62、 }AdjMGraph; //邊的結(jié)構(gòu)體定義</p><p> void Initiate(AdjMGraph *G,int n) //初始化</p><p><b> {</b></p><p><b> int i,j;</b></p><p> for(i=0;i<n;i+
63、+)</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><b> else</
64、b></p><p> G->edge[i][j]=MaxWeight;</p><p><b> }</b></p><p> G->numOfEdges=0; //邊的條數(shù)置為0</p><p> ListInitiate(&G->Vertices); //順序表初始化
65、</p><p><b> }</b></p><p> void InsertVertex(AdjMGraph *G,DataType vertex) //在圖G中插入結(jié)點vertex</p><p><b> {</b></p><p> ListInsert(&G->V
66、ertices,G->Vertices.size,vertex); //順序表尾插入</p><p><b> }</b></p><p> void InsertEdge(AdjMGraph *G,int v1,int v2,int weight)</p><p> //在圖G中插入邊<v1,v2>,邊<v1,
67、v2>的權(quán)為weight</p><p><b> {</b></p><p> if(v1<0||v1>G->Vertices.size||v2<0||v2>G->Vertices.size)</p><p><b> {</b></p><p>
68、 printf("參數(shù)v1或v2越界出錯!\n");</p><p><b> exit(1);</b></p><p><b> }</b></p><p> G->edge[v1][v2]=weight;</p><p> G->numOfEdges++;
69、</p><p><b> }</b></p><p> void DeleteEdge(AdjMGraph *G,int v1,int v2) //在圖中刪除邊<v1,v2></p><p><b> {</b></p><p> if(v1<0||v1>G-&g
70、t;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);</b></p>
71、;<p><b> }</b></p><p> if(G->edge[v1][v2]==MaxWeight||v1==v2)</p><p><b> {</b></p><p> printf("該邊不存在!\n");</p><p><b&
72、gt; exit(0);</b></p><p><b> }</b></p><p> G->edge[v1][v2]=MaxWeight;</p><p> G->numOfEdges--;</p><p><b> }</b></p><p
73、> void DeleteVerten(AdjMGraph *G,int v) //刪除結(jié)點v</p><p><b> {</b></p><p> int n=ListLength(G->Vertices),i,j; </p><p> DataType x;</p><p> for(i=
74、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][j]<MaxWeight)&
75、lt;/p><p> G->numOfEdges--; //計算被刪除邊</p><p><b> }</b></p><p> for(i=v;i<n;i++) //刪除第v行</p><p><b> {</b></p><p> for(j=0;j
76、<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> {</b></p>&l
77、t;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); //刪除結(jié)點v</p><p
78、><b> }</b></p><p> int GetFistVex(AdjMGraph *G,int v) </p><p> //在圖G中尋找序號為v的結(jié)點的第一個鄰接結(jié)點</p><p> //如果這樣的鄰接結(jié)點存在,返回該鄰接結(jié)點的序號;否則,返回-1</p><p><b> {&
79、lt;/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越界出錯!\n");<
80、/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]>0&&G->
81、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> //在圖中尋找v1結(jié)點的鄰接結(jié)點v2的下
82、一個鄰接結(jié)點</p><p> //如果這樣的結(jié)點存在,返回該鄰接結(jié)點的序號;否則,返回-1</p><p> //v1和v2都是相應(yīng)結(jié)點的序號</p><p><b> {</b></p><p><b> int col;</b></p><p> if(v1&
83、lt;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); </p><
84、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;</p><p>
85、; return -1;</p><p><b> }</b></p><p> //輸出圖G的鄰接矩陣</p><p> void Print(AdjMGraph *G) </p><p><b> {</b></p><p><b> int i,
86、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> printf("%6d "
87、;,G->edge[i][j]);</p><p> printf("\n");</p><p><b> }</b></p><p><b> }</b></p><p> //鄰接矩陣存儲結(jié)構(gòu)下求出每個頂點的度并輸出</p><p>
88、void MVertices(AdjMGraph *G,DataType a[]) </p><p><b> {</b></p><p> int i,j,m;</p><p> DataType b[MaxVertices];//用數(shù)組b[]記錄相應(yīng)結(jié)點的度</p><p> for(i=0;i<G-
89、>Vertices.size;i++)</p><p> b[i]=0; //置0</p><p> printf("鄰接矩陣存儲結(jié)構(gòu)下圖的頂點的度為:\n");</p><p> for(m=0;m<G->Vertices.size;m++) //求出每個結(jié)點的度</p><p><b&
90、gt; {</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> if(i==m&&G
91、->edge[i][j]>0&&G->edge[i][j]<MaxWeight)</p><p> //求出鄰接矩陣第i行權(quán)值存在的邊的個數(shù),當(dāng)邊<m,j>存在時,b[m]加1</p><p><b> b[m]++;</b></p><p> if(j==m&&i!=m
92、&&G->edge[i][j]>0&&G->edge[i][j]<MaxWeight)</p><p> //求出鄰接矩陣第j列權(quán)值存在的邊的個數(shù),當(dāng)邊<i,m>存在時,b[m]加1</p><p><b> b[m]++;</b></p><p><b> }
93、</b></p><p> printf("頂點%d的度為:%d\n",a[m],b[m]);</p><p><b> }</b></p><p><b> }</b></p><p> //查找圖G中是否存在點v</p><p>
94、 int ChaZhao(AdjMGraph *G,int v) </p><p><b> {</b></p><p> if(0<=v&&v<G->Vertices.size)</p><p><b> {</b></p><p> printf(&q
95、uot;存在頂點%d\n",v);</p><p><b> return 1;</b></p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><
96、;p> printf("不存在頂點%d\n",v);</p><p><b> return 0;</b></p><p><b> }</b></p><p><b> }</b></p><p> //刪除查找到的結(jié)點v并刪除該結(jié)點及與之
97、相關(guān)的邊</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.size;i++)</p>
98、<p><b> {</b></p><p> if(G->edge[v][i]>0&&G->edge[v][i]<MaxWeight)</p><p> //當(dāng)鄰接矩陣的第v行有邊<v,i>存在時,刪除邊<v,i></p><p> DeleteEdge(G
99、,v,i);</p><p> if(G->edge[i][v]>0&&G->edge[i][v]<MaxWeight)</p><p> //當(dāng)鄰接矩陣的第j行有邊<i,v>存在時,刪除邊<i,v></p><p> DeleteEdge(G,i,v);</p><p>
100、<b> }</b></p><p> DeleteVerten(G,v);//刪除結(jié)點v</p><p><b> }</b></p><p> (4)/* 文件AdjMGraphCreate.h */</p><p> typedef struct</p><p&g
101、t;<b> {</b></p><p> int row; //行下標(biāo)</p><p> int col; //列下標(biāo)</p><p> int weight; //權(quán)值</p><p> }RowColWeight; //邊信息結(jié)構(gòu)體定義</p><p> void Cre
102、atGraph(AdjMGraph *G,DataType v[],int n,RowColWeight E[],int e)</p><p> //在圖G中插入n個結(jié)點信息v和e條邊信息E</p><p><b> {</b></p><p><b> int i,k;</b></p><p&g
103、t; Initiate(G,n); //結(jié)點順序表初始化</p><p> for(i=0;i<n;i++)</p><p> InsertVertex(G,v[i]); //結(jié)點插入</p><p> for(k=0;k<e;k++)</p><p> InsertEdge(G,E[k].row,E[k].col,
104、E[k].weight); //邊插入</p><p><b> }</b></p><p> (5)/* 文件AdjLGraph.h */</p><p> //鄰接表的存儲結(jié)構(gòu)</p><p> typedef struct Node </p><p><b> {&l
105、t;/b></p><p> int dest; //鄰接邊的弧頭結(jié)點序號</p><p> struct Node *next; </p><p> }Edge; //鄰接邊單鏈表的結(jié)點結(jié)構(gòu)體</p><p> typedef struct</p><p><b> {</b&g
106、t;</p><p> DataType data; //結(jié)點數(shù)據(jù)元素 </p><p> int sorce; //鄰接邊的弧尾結(jié)點序號</p><p> Edge *adj; //鄰接邊的頭指針</p><p> }AdjLHeight; //數(shù)組的數(shù)據(jù)元素類型結(jié)構(gòu)體</p><p> typed
107、ef struct</p><p><b> {</b></p><p> AdjLHeight a[MaxVertices]; //鄰接表數(shù)組</p><p> int numOfVerts; //結(jié)點個數(shù)</p><p> int numOfEdges; //邊個數(shù)</p><p&g
108、t; }AdjLGraph; //鄰接表結(jié)構(gòu)體</p><p><b> //初始化操作函數(shù)</b></p><p> void LAdjInitiate(AdjLGraph *G)</p><p><b> {</b></p><p><b> int i;</b>
109、;</p><p> G->numOfVerts=0;</p><p> G->numOfEdges=0;</p><p> for(i=0;i<MaxVertices;i++)</p><p><b> {</b></p><p> G->a[i].sorce=
110、i;</p><p> G->a[i].adj=NULL;</p><p><b> }</b></p><p><b> }</b></p><p><b> //撤銷操作函數(shù)</b></p><p> void LAdjDestroy
111、(AdjLGraph *G)</p><p> //撤銷圖G中的所有鄰接邊單鏈表</p><p><b> {</b></p><p><b> int i;</b></p><p> Edge *p,*q;</p><p> for(i=0;i<G->
112、numOfVerts;i++)</p><p><b> {</b></p><p> p=G->a[i].adj;</p><p> while(p!=NULL)</p><p><b> {</b></p><p> q=p->next;</p
113、><p><b> free(p);</b></p><p><b> p=q;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b>&
114、lt;/p><p> //插入結(jié)點操作函數(shù)</p><p> void LInsertVertex(AdjLGraph *G,int i,DataType vertex)</p><p> //在圖G中的第i(0<=i<MaxVertices)個位置插入結(jié)點數(shù)據(jù)元素vertex</p><p><b> {</
115、b></p><p> if(i>=0&&i<MaxVertices)</p><p><b> {</b></p><p> G->a[i].data=vertex; //存儲結(jié)點數(shù)據(jù)元素vertex</p><p> G->numOfVerts++;
116、//個數(shù)加1</p><p><b> }</b></p><p><b> else</b></p><p> printf("結(jié)點越界");</p><p><b> }</b></p><p><b> //
117、插入邊操作函數(shù)</b></p><p> void LInsertEdge(AdjLGraph *G,int v1,int v2)</p><p> //在圖G中加入邊<v1,v2>的信息</p><p><b> {</b></p><p> Edge *p; //定義一個鄰接邊指針&
118、lt;/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><b>
119、 exit(0);</b></p><p><b> }</b></p><p> p=(Edge *)malloc(sizeof(Edge)); //申請鄰接邊單鏈表結(jié)點空間</p><p> p->dest=v2; //置鄰接邊弧頭序號</p><p> p->next=G-&g
120、t;a[v1].adj; //新結(jié)點插入單鏈表的表頭</p><p> G->a[v1].adj=p; //頭指針指向新的單鏈表表頭</p><p> G->numOfEdges++; //邊數(shù)個數(shù)加1</p><p><b> } </b></p><p><b> //刪除邊操作函
121、數(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,*pre;</p>&
122、lt;p> if(v1<0||v1>=G->numOfVerts||v2<0||v2>=G->numOfVerts)</p><p><b> {</b></p><p> printf("參數(shù)v1或v2越界出錯!");</p><p><b> exit(0);&
123、lt;/b></p><p><b> }</b></p><p><b> pre=NULL;</b></p><p> curr=G->a[v1].adj;</p><p> while(curr!=NULL&&curr->dest!=v2)</p
124、><p> //在v1結(jié)點的鄰接邊單鏈表中查找v2結(jié)點</p><p><b> {</b></p><p><b> pre=curr;</b></p><p> curr=curr->next;</p><p><b> }</b><
125、;/p><p> //刪除表示鄰接邊<v1,v2>的結(jié)點</p><p> if(curr!=NULL&&curr->dest==v2&&pre==NULL)</p><p> //當(dāng)鄰接邊<v1,v2>的結(jié)點是單鏈表的第一個結(jié)點時</p><p><b> {<
126、;/b></p><p> G->a[v1].adj=curr->next;</p><p> free(curr);</p><p> G->numOfEdges--;</p><p><b> }</b></p><p> else if(curr!=NULL
127、&&curr->dest==v2&&pre!=NULL)</p><p> //當(dāng)鄰接邊<v1,v2>的結(jié)點不是單鏈表的第一個結(jié)點時</p><p><b> {</b></p><p> pre->next=curr->next;</p><p>
128、 free(curr);</p><p> G->numOfEdges--;</p><p><b> }</b></p><p><b> else</b></p><p> //當(dāng)鄰接邊<v1,v2>結(jié)點不存在時</p><p> printf
129、("邊<v1,v2>不存在時");</p><p><b> }</b></p><p> //取第一個鄰接結(jié)點</p><p> int LGetFirstVex(AdjLGraph *G,int v)</p><p> //取圖G中結(jié)點v的第一個鄰接結(jié)點</p>
130、<p> //取到時返回該鄰接結(jié)點的對應(yīng)序號,否則返回-1</p><p><b> {</b></p><p><b> Edge *p;</b></p><p> if(v<0||v>G->numOfVerts)</p><p><b> {<
131、;/b></p><p> printf("參數(shù)v1或v2越界出錯!");</p><p><b> exit(0);</b></p><p><b> }</b></p><p> p=G->a[v].adj;</p><p> i
132、f(p!=NULL)</p><p> return p->dest; //返回該鄰接結(jié)點的對應(yīng)序號</p><p><b> else</b></p><p> return -1; //返回-1</p><p><b> }</b></p><p>
133、//取下一個鄰接結(jié)點</p><p> int LGetNextVex(AdjLGraph *G,int v1,int v2)</p><p> //取圖G中結(jié)點v1的鄰接結(jié)點v2的下一個鄰接結(jié)點</p><p> //取到時返回該鄰接結(jié)點的對應(yīng)序號,否則返回-1</p><p><b> {</b></p
134、><p><b> Edge *p;</b></p><p> if(v1<0||v1>G->numOfVerts||v2<0||v2>G->numOfVerts)</p><p><b> {</b></p><p> printf("參數(shù)v1或v
135、2越界出錯!");</p><p><b> exit(0);</b></p><p><b> }</b></p><p> p=G->a[v1].adj;</p><p> while(p!=NULL) //尋找結(jié)點v1的鄰接結(jié)點v2</p><p&
136、gt;<b> {</b></p><p> if(p->dest!=v2)</p><p><b> {</b></p><p> p=p->next;</p><p><b> continue;</b></p><p><
137、;b> }</b></p><p><b> else</b></p><p><b> break;</b></p><p><b> }</b></p><p> p=p->next; //p指向鄰接結(jié)點v2的下一個鄰接結(jié)點</p&
138、gt;<p> if(p!=NULL)</p><p> return p->dest; //返回該鄰接結(jié)點的對應(yīng)序號</p><p><b> else</b></p><p> return -1; //返回-1</p><p><b> }</b></p
139、><p> //鄰接表存儲下求每個頂點的度并輸出結(jié)果</p><p> void LVertices(AdjLGraph *G,DataType a[])</p><p><b> {</b></p><p> printf("鄰接表存儲結(jié)構(gòu)下的圖的頂點的度為:\n");</p>&
140、lt;p> int OutDegree[MaxVertices],InDegree[MaxVertices];//定義一個出度和入度的數(shù)組</p><p><b> int i;</b></p><p> for(i=0;i<G->numOfVerts;i++) //首先將出度和入度數(shù)組的每個成員都置0</p><p>
141、;<b> {</b></p><p> OutDegree[i]=0;</p><p> InDegree[i]=0;</p><p><b> }</b></p><p> Edge *p; //定義一個鄰接邊指針</p><p> for(i=0;i<
142、;G->numOfVerts;i++)</p><p><b> {</b></p><p> p=G->a[i].adj; //指針指向a[i]的鄰接邊單鏈表頭結(jié)點</p><p> while(p!=NULL)//當(dāng)p所指向的鄰接邊結(jié)點不空時</p><p><b> {</b&
143、gt;</p><p> OutDegree[i]++; //出度加1</p><p> InDegree[p->dest]++; //鄰接邊弧頭結(jié)點的入度加1</p><p> p=p->next; //p指向下一個鄰接邊結(jié)點</p><p><b> }</b></p><p&
144、gt;<b> }</b></p><p> for(i=0;i<G->numOfVerts;i++) //輸出每個結(jié)點的度</p><p><b> {</b></p><p> printf("頂點%d的度為:",a[i]);</p><p> prin
145、tf("%d",OutDegree[i]+InDegree[i]); //每個結(jié)點的度即出度與入度相加的和</p><p> printf("\n");</p><p><b> }</b></p><p><b> }</b></p><p> //
146、判斷有向圖G是否為強(qiáng)連通圖</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<G->numOfVerts;
147、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></p><p>
148、; 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><p><b> }&l
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 圖的基本操作與實現(xiàn)的課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---skiplist基本操作
- 對于串及其基本操作的課程設(shè)計
- 課程設(shè)計--靜態(tài)查找的實現(xiàn)操作
- 串的存儲表示及基本操作_課程設(shè)計
- 數(shù)據(jù)庫課程設(shè)計---串的基本操作
- 操作系統(tǒng)課程設(shè)計報告---進(jìn)程調(diào)度的模擬實現(xiàn)
- 課程設(shè)計--《哈希表的操作》設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計報告---圖的算法實現(xiàn)
- 操作系統(tǒng)課程設(shè)計---geekos操作系統(tǒng)的研究與實現(xiàn)
- 《matlab課程設(shè)計》報告-matlab的基本運算與繪圖
- 操作系統(tǒng)課程設(shè)計-- geekos操作系統(tǒng)的研究與實現(xiàn)
- 二叉樹的基本操作課程設(shè)計
- 操作系統(tǒng)文件系統(tǒng)的設(shè)計與實現(xiàn)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計--模擬操作系統(tǒng)的實現(xiàn)
- 課程設(shè)計報告---排序算法的實現(xiàn)與比較
- 文件系統(tǒng)的設(shè)計與實現(xiàn) 課程設(shè)計報告
- 操作系統(tǒng)程序設(shè)計課程設(shè)計報告-操作系統(tǒng)模擬實現(xiàn)
- 課程設(shè)計--實現(xiàn)字符串的多種操作
- 課程設(shè)計報告--校園導(dǎo)游系統(tǒng)的設(shè)計與實現(xiàn)
評論
0/150
提交評論