版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 圖的遍歷課程設(shè)計(jì)
- 圖的遍歷課程設(shè)計(jì)
- 圖的遍歷實(shí)現(xiàn)課程設(shè)計(jì)--圖的遍歷的實(shí)現(xiàn)
- 課程設(shè)計(jì)論文-圖的遍歷
- 圖的廣度遍歷課程設(shè)計(jì)報(bào)告
- 圖遍歷的演示課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-----圖的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---圖的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告(圖的遍歷)
- 《圖的建立與遍歷》數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---圖的存儲(chǔ)與遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-圖的遍歷和構(gòu)建
- 圖的廣度優(yōu)先遍歷-數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-- 圖的遍歷和生成樹(shù)求解
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---圖的遍歷和生成樹(shù)求解
- 遍歷二叉樹(shù)課程設(shè)計(jì)
- 新數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---圖的遍歷和生成樹(shù)求解實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--二叉樹(shù)的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-圖的遍歷和生成樹(shù)的求解實(shí)現(xiàn)說(shuō)明書(shū)
- 《數(shù)據(jù)結(jié)構(gòu)遍歷二叉樹(shù)》課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論