版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p> 設(shè)計(jì)題目:圖的建立與輸出</p><p> 系 別: 電子與信息工程學(xué)院 </p><p> 專 業(yè): 電子信息工程 </p><p> 班 級(jí): 2009級(jí)(1)班 </
2、p><p> 姓 名: </p><p> 學(xué) 號(hào): </p><p> 指導(dǎo)教師: </p><p> 2011年 06 月 20日</p><p><b> 目錄</b></p>
3、;<p> 一、設(shè)計(jì)題目(任選其一)…………………………………………3</p><p> 二、運(yùn)行環(huán)境(軟、硬件環(huán)境)……………………………………3</p><p> 三、算法設(shè)計(jì)的思想…………………………………………………3</p><p> 四、算法的流程圖……………………………………………………3</p><p>
4、 五、算法設(shè)計(jì)分析……………………………………………………4</p><p> 六、源代碼……………………………………………………………4</p><p> 七、運(yùn)行結(jié)果分析……………………………………………………14</p><p> 八、收獲及體會(huì)………………………………………………………16</p><p> 一、設(shè)計(jì)題目(任
5、選其一)</p><p><b> 圖的建立及輸出</b></p><p> 任務(wù):建立圖的存儲(chǔ)結(jié)構(gòu)(圖的類型可以是有向圖、無(wú)向圖、有向網(wǎng)、無(wú)向網(wǎng),學(xué)生可以任選兩種類型),能夠輸入圖的頂點(diǎn)和邊的信息,并存儲(chǔ)到相應(yīng)存儲(chǔ)結(jié)構(gòu)中,而后輸出圖的鄰接矩陣。 </p><p> 二、運(yùn)行環(huán)境(軟、硬件環(huán)境)</p><p>&
6、lt;b> 硬件環(huán)境:</b></p><p> CPU:1000MHz以上</p><p> 內(nèi)存:256MB以上</p><p><b> 硬盤:60G以上</b></p><p><b> 軟件環(huán)境:</b></p><p> 系統(tǒng)平臺(tái):
7、Windows 2000 / Windows XP / Windows Vista / Windows 7 </p><p> 運(yùn)行環(huán)境:TC 3.0 / Microsoft Visual C++ 6.0</p><p><b> 三、算法設(shè)計(jì)的思想</b></p><p> 1、存儲(chǔ)結(jié)構(gòu);鄰接矩陣 鄰接表</p><
8、p> 2、遍歷方式:深度優(yōu)先搜索(DFS) 廣度優(yōu)先搜索(BFS) 也可以對(duì)鄰接矩陣和臨界表直接輸出:其中DFS算法通過(guò)遞歸實(shí)現(xiàn),BFS算法通過(guò)隊(duì)列實(shí)現(xiàn)。</p><p> 3、拓?fù)渑判蚝妥钚∩蓸?shù)(Prime算法),具體實(shí)現(xiàn)見(jiàn)代碼。</p><p><b> 四、算法的流程圖</b></p><p><b> 五、算法
9、設(shè)計(jì)分析</b></p><p> 首先是建圖,圖和網(wǎng)的區(qū)別在于圖沒(méi)有權(quán)值(這里以固定值1代替),網(wǎng)有權(quán)值,有向和無(wú)向在存儲(chǔ)上的區(qū)別在于對(duì)于有向圖,輸入a[i][j],只存儲(chǔ)a[i][j],而對(duì)于無(wú)向圖還要存儲(chǔ)a[j][i]。</p><p> 其次是功能的實(shí)現(xiàn),鄰接表遍歷和鄰接矩陣遍歷都很簡(jiǎn)單,按照它的存儲(chǔ)結(jié)構(gòu),依次輸出每個(gè)頂點(diǎn)和它鄰接的頂點(diǎn),時(shí)間復(fù)雜度分別為O(n+e)
10、和O(n2);</p><p> 對(duì)于DFS算法是通過(guò)函數(shù)遞歸實(shí)現(xiàn)的,所采用的存儲(chǔ)結(jié)構(gòu)式是鄰接表,找鄰接點(diǎn)所需時(shí)間為O(e),其中e為無(wú)向圖的邊數(shù)或有向圖的弧數(shù),時(shí)間復(fù)雜度為O(n+e)。</p><p> 對(duì)于BFS算法是用隊(duì)列實(shí)現(xiàn)的,每個(gè)頂點(diǎn)至多進(jìn)一次隊(duì)列。遍歷圖的過(guò)程實(shí)質(zhì)上是通過(guò)邊或弧找鄰接點(diǎn)的過(guò)程,因此廣度優(yōu)先搜索遍歷圖的時(shí)間復(fù)雜度和深度優(yōu)先搜索遍歷相同,兩者不同之處僅僅在于對(duì)
11、每個(gè)頂點(diǎn)訪問(wèn)的順序不同</p><p> 對(duì)于拓?fù)渑判?,建立各?xiàng)頂點(diǎn)的入度的時(shí)間復(fù)雜度為O(e),建零入度頂點(diǎn)棧的時(shí)間復(fù)雜度為O(n);在拓?fù)渑判蜻^(guò)程中,若有向圖無(wú)環(huán),則每個(gè)頂點(diǎn)進(jìn)一次棧,出一次棧,入度減1的操作在while語(yǔ)句中總共執(zhí)行e次,所以總的時(shí)間復(fù)雜度為O(n+e)。</p><p> 對(duì)于Prime算法的最小生成樹(shù),假設(shè)網(wǎng)中有n個(gè)頂點(diǎn),則第一個(gè)進(jìn)行初始化的循環(huán)語(yǔ)句的頻度為n
12、,第二個(gè)循環(huán)語(yǔ)句的頻度為n-1。其二是重新選擇具有最小代價(jià)的邊,其頻度為n。由此,Prime算法的時(shí)間復(fù)雜度為O(n2),與網(wǎng)中的邊數(shù)無(wú)關(guān),因此適用于求邊稠密的網(wǎng)的最小生成樹(shù)。</p><p><b> 六、源代碼 </b></p><p> #include <stdio.h></p><p> #include <
13、string.h></p><p> #include <stdlib.h></p><p> #include <ctype.h></p><p> #include <queue></p><p> #include <stack></p><p>
14、#include <process.h></p><p> using namespace std;</p><p> #define MAX_VERTEX_NUM 20</p><p> #define MAX 1000</p><p> #define DG 1</p><p> #defin
15、e DN 2</p><p> #define UDG 3</p><p> #define UDN 4</p><p> //typedef enum{DG,DN,UDG,UDN} GraphKind;</p><p> typedef char VertexType;</p><p> typedef
16、int VRType;</p><p> typedef char InfoType;</p><p> struct Close {</p><p> VertexType data;//頂點(diǎn)元素</p><p> VRType lowcost;</p><p><b> int j;</
17、b></p><p> }closedge[MAX_VERTEX_NUM]; //prime算法秋最小生成樹(shù)的輔助數(shù)組</p><p> typedef struct ArcNode{</p><p> int adjvex;//該弧所指向的頂點(diǎn)的位置</p><p> struct ArcNode *nextarc;/
18、/指向下一條弧的指針</p><p> int adj;//對(duì)于無(wú)權(quán)圖為0 或1;對(duì)于帶權(quán)圖為權(quán)值</p><p> InfoType *info;//該弧相關(guān)信息的指針</p><p> }ArcNode,AdjMartrix[MAX_VERTEX_NUM][MAX_VERTEX_NUM];//為簡(jiǎn)便起見(jiàn)鄰接矩陣的元素類型,此時(shí)部分元素?zé)o用&l
19、t;/p><p> typedef struct VNode{</p><p> int outdegree,indegree;</p><p> VertexType data;//頂點(diǎn)信息</p><p> ArcNode *firstarc;//指向第一條依附該頂點(diǎn)的弧的指針</p><p> }VNode
20、,AdjList[MAX_VERTEX_NUM];</p><p> typedef struct Graph{</p><p> AdjList vertices; //鄰接表</p><p> AdjMartrix arcs; //鄰接矩陣</p><p> int vexnum,arcnum; // 頂點(diǎn)個(gè)數(shù)及邊的數(shù)量
21、</p><p> int kind; //圖的類型</p><p><b> }ALGraph;</b></p><p> int cmp(const void *a,const void *b)</p><p><b> {</b></p><p
22、> if( *(char *)a-*(char *)b>=0)</p><p><b> return 1;</b></p><p> return -1;</p><p><b> }</b></p><p> int LocateVex(ALGraph & G,
23、VertexType e ){</p><p> for(int i=1;i<=G.vexnum;i++)</p><p> if(G.vertices[i].data==e) </p><p><b> return i;</b></p><p><b> return 0;</b>
24、</p><p><b> } </b></p><p> void Input_V(AdjList & ver,int n)</p><p><b> {</b></p><p> bool f=false;</p><p> char str[30];&
25、lt;/p><p> memset(str,0,sizeof(str));</p><p> printf("輸入每個(gè)頂點(diǎn):用字母數(shù)字 如 ABCDEF 表示六個(gè)頂點(diǎn):");</p><p> while(!f&&gets(str)){</p><p> int len=strlen(str);&
26、lt;/p><p> if(!len){ printf("\t\t你沒(méi)有輸入數(shù)據(jù),請(qǐng)輸入數(shù)據(jù):"); continue;}</p><p> if(len<n){ printf("\t\t輸入長(zhǎng)度不夠,請(qǐng)重新輸入:"); continue;}</p><p> for(int i=0;i<n;i++)</p
27、><p> ver[i+1].data=str[i];</p><p> for( i=0;i<len;i++)</p><p> if(!(str[i]>='a'&&str[i]<='z'||str[i]>='A'&&str[i]<='Z'
28、;||str[i]>='0'&&str[i]<='9'))</p><p><b> break;</b></p><p> if(i<len) { printf("\t\t輸入非法字符,請(qǐng)重新輸入:"); continue;}</p><p>
29、qsort(str,len,sizeof(char),cmp);</p><p> for(i=0;i<len-1;i++)</p><p> if(str[i]==str[i+1]) break;</p><p> if(i<len-1){ printf("\t\t不能有兩個(gè)相同的字符,請(qǐng)重新輸入:"); continue;
30、} </p><p><b> f=true;</b></p><p> memset(str,0,sizeof(str));</p><p> //puts(str);</p><p><b> }</b></p><p><b> }</b>
31、;</p><p> void initGraph( ALGraph & G) // 初始化圖 包括 輸入頂點(diǎn)和弧的數(shù)目,并初始化鄰接表的數(shù)組</p><p><b> {</b></p><p> int a=-1,b=-1;</p><p> char str[23];</p>&
32、lt;p> printf("\t\t輸入頂點(diǎn)個(gè)數(shù)和弧的個(gè)數(shù):");</p><p><b> do{</b></p><p> scanf("%d%d%*c",&a,&b);</p><p> if(a==-1||b==-1) {</p><p>
33、gets(str);</p><p> printf("\t\t輸入不合法,請(qǐng)重新輸入:");</p><p><b> }</b></p><p> else break;</p><p> }while(1);</p><p> printf("%d %
34、d \n",a,b);</p><p> G.vexnum=a; G.arcnum=b;</p><p> Input_V(G.vertices,G.vexnum);</p><p> for(int i=1;i<=G.vexnum;i++){</p><p> //scanf("%d",&
35、;(G.vertices[i].data));// 構(gòu)造頂點(diǎn)向量</p><p> for(int j=1;j<=G.vexnum;j++){//初始化矩陣</p><p> G.arcs[i][j].adj=MAX;</p><p> G.arcs[i][j].info=NULL;</p><p><b> }&
36、lt;/b></p><p> G.vertices[i].indegree=0;</p><p> G.vertices[i].outdegree=0;</p><p> G.vertices[i].firstarc=NULL;</p><p><b> }</b></p><p>
37、;<b> }</b></p><p> void Input(char & v1,char & v2,int &d ,ALGraph & G)</p><p><b> {</b></p><p> char str[30];</p><p><b
38、> int i;</b></p><p> bool flag=false;</p><p> memset(str,0,sizeof(str));</p><p> while(!flag&&gets(str)){</p><p> int length =strlen(str);</p&g
39、t;<p> for(i=4;i<length;i++){</p><p> if(!isalnum(str[0])||!isalnum(str[2])) break;</p><p> if(str[1]!=' '||str[3]!=' ') break;</p><p> if(!isdigit(st
40、r[i])) break;</p><p><b> }</b></p><p> if(length<5||i<length) { printf("存在不不合法字符或輸入格式錯(cuò)誤 請(qǐng)重新輸入\n"); continue;}</p><p> //printf("%d %s\n",le
41、ngth,str);</p><p> for(i=4,d=0;i<length;i++)</p><p> d=d*10+str[i]-'0';</p><p> if((G.kind==1||G.kind==3)&&d!=1) { printf("存在不不合法字符或輸入格式錯(cuò)誤 請(qǐng)重新輸入\n");
42、 continue;}</p><p> v1=str[0]; v2=str[2];</p><p> flag=true;</p><p> memset(str,0,sizeof(str));</p><p><b> }</b></p><p><b> }</b&
43、gt;</p><p> int CreateDG_DN_UDG_UDN(ALGraph & G){ // 有向圖、有向網(wǎng)、無(wú)向圖、無(wú)向網(wǎng)以及鄰接矩陣的具體實(shí)現(xiàn)</p><p> VertexType v1,v2;</p><p> int weight;</p><p> int flag=G.kind;</p&
44、gt;<p> initGraph(G);</p><p> int tem=G.arcnum;</p><p> printf("每條邊依附的兩個(gè)定點(diǎn)及其權(quán)值(>0),無(wú)權(quán)輸入1 如 A B 20 和 A B 1 \n");</p><p> while(tem--){</p><p>
45、 Input(v1,v2,weight,G);</p><p> int i=LocateVex(G,v1); // 定位v1 v2在數(shù)組中的位置</p><p> int j=LocateVex(G,v2);</p><p> G.arcs[i][j].adj=flag==1||flag==3?1:weight; // 建立鄰接矩陣</p>
46、;<p> if(flag==3||flag==4){</p><p> G.arcs[j][i].adj=flag==3?1:weight;</p><p><b> }</b></p><p> ArcNode * q=(ArcNode *)malloc(sizeof(ArcNode));</p><
47、;p> q->adj=weight;</p><p> q->adjvex=j;</p><p> q->nextarc=NULL;</p><p> if(G.vertices[i].outdegree==0) </p><p> G.vertices[i].firstarc=q; </p>
48、<p><b> else{</b></p><p> ArcNode *p=G.vertices[i].firstarc;</p><p> while(p->nextarc)</p><p> p=p->nextarc;</p><p> p->nextarc=q;</
49、p><p><b> }</b></p><p> if(flag==3||flag==4){ // 此if 語(yǔ)句是為創(chuàng)建無(wú)向圖 及 無(wú)向網(wǎng)準(zhǔn)備的</p><p> ArcNode * q=(ArcNode *)malloc(sizeof(ArcNode));</p><p> q->adj=weigh
50、t;</p><p> q->adjvex=i;</p><p> q->nextarc=NULL;</p><p> if(G.vertices[j].outdegree==0&&G.vertices[j].indegree==0) </p><p> G.vertices[j].firstarc=q;&
51、lt;/p><p><b> else{</b></p><p> ArcNode *p=G.vertices[j].firstarc;</p><p> while(p->nextarc)</p><p> p=p->nextarc;</p><p> p->nextar
52、c=q;</p><p><b> }</b></p><p><b> }</b></p><p> G.vertices[i].outdegree++;</p><p> if(flag==3||flag==4) G.vertices[j].outdegree++;</p>
53、<p><b> else </b></p><p> G.vertices[j].indegree++;</p><p><b> }</b></p><p><b> return 0;</b></p><p><b> }</b>
54、;</p><p> void VisitDG_DN_UDG_UDN(ALGraph & G,int f){ // 遍歷鄰接表,</p><p> ArcNode *p;</p><p><b> if(f){</b></p><p> printf("\t\t遍歷鄰接表 :\n");
55、</p><p> for(int i=1;i<=G.vexnum;i++){</p><p> p=G.vertices[i].firstarc;</p><p> printf("\t\t與第%d個(gè)頂點(diǎn)%c鄰接頂點(diǎn)有:",i,G.vertices[i].data);</p><p><b>
56、 while(p){</b></p><p> printf("%c ",G.vertices[p->adjvex].data);</p><p> p=p->nextarc;</p><p><b> }</b></p><p> if(G.kind==3||G.ki
57、nd==4) printf("度數(shù)為 %d ",G.vertices[i].outdegree);</p><p> else printf("出度為 %d ,入度為 %d ",G.vertices[i].outdegree,G.vertices[i].indegree);</p><p> printf("\n");<
58、;/p><p><b> }</b></p><p><b> }</b></p><p><b> else{</b></p><p> printf("遍歷鄰接矩陣 :\n\t\t ");</p><p> for(in
59、t i=1;i<=G.vexnum;i++)</p><p> printf("%c %c",G.vertices[i].data,i==G.vexnum?'\n':' ');</p><p> printf("\t\t─┼────────────────\n");</p><p>
60、; //printf("─┼───────\n │\n │");</p><p> for( i=1;i<=G.vexnum;i++){</p><p> printf("\t\t%c │",G.vertices[i].data);</p><p> for(int j=1;j<=G.vexnum;
61、j++)</p><p> //printf("%5d%c",G.arcs[i][j].adj,j==G.vexnum?'\n':' ');</p><p> if(G.arcs[i][j].adj==MAX) printf("∞ %c",j==G.vexnum?'\n':' '
62、);</p><p> else printf("%d %c",G.arcs[i][j].adj,j==G.vexnum?'\n':' ');</p><p><b> }</b></p><p><b> }</b></p><p>&
63、lt;b> }</b></p><p> bool visit[MAX_VERTEX_NUM];//深度優(yōu)先搜索</p><p> void DFS(ALGraph & G,int i){</p><p> visit[i]=true; </p><p> printf("%c ",G
64、.vertices[i].data);</p><p> ArcNode * p;</p><p> for(p=G.vertices[i].firstarc;p;p=p->nextarc){</p><p> if(!visit[p->adjvex]) DFS(G,p->adjvex); </p><p>&
65、lt;b> }</b></p><p><b> } </b></p><p> void DFSTraverse(ALGraph & G){ </p><p><b> int i;</b></p><p> printf("\t\t深度優(yōu)先搜索
66、:");</p><p> for( i=0;i<MAX_VERTEX_NUM;i++)</p><p> visit[i]=false;</p><p> for( i=1;i<=G.vexnum;i++)</p><p> if(!visit[i]) DFS(G,i); </p><p&
67、gt;<b> }</b></p><p> queue <int> Q;</p><p> void BFSTraverse(ALGraph & G) //廣度優(yōu)先搜索</p><p><b> {</b></p><p><b> int i,j;<
68、;/b></p><p> printf("\n\t\t廣度優(yōu)先搜索 :");</p><p> for( i=0;i<MAX_VERTEX_NUM;i++)</p><p> visit[i]=false;</p><p> for(i=1;i<=G.vexnum;i++){</p>
69、<p> if(!visit[i]){</p><p> visit[i]=true; </p><p> printf("%c ",G.vertices[i].data);</p><p> Q.push(i);</p><p> while(!Q.empty()){</p>&l
70、t;p> j=Q.front();</p><p><b> Q.pop();</b></p><p> for(ArcNode *w=G.vertices[j].firstarc;w;w=w->nextarc)</p><p> if(!visit[w->adjvex]){</p><p>
71、 visit[w->adjvex]=true; </p><p> printf("%c ",G.vertices[w->adjvex].data);</p><p> Q.push(w->adjvex);</p><p><b> }</b></p><p><b>
72、; }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> void MinSpanTree_PRIM(ALGraph G,VertexType u)// prim算法
73、的最小生成樹(shù)</p><p><b> {</b></p><p> if(G.kind!=UDN) {printf("沒(méi)有最小成樹(shù)\n");return;}</p><p> int i,j,k;</p><p> int mincost=0;</p><p> p
74、rintf("\n\t\tprim算法的最小生成樹(shù) :");</p><p> k=LocateVex(G,u);</p><p> for(i=1;i<=G.vexnum;i++){</p><p> closedge[i].data=G.vertices[i].data;</p><p> closedg
75、e[i].lowcost=G.arcs[k][i].adj;</p><p> closedge[i].j=k;</p><p><b> }</b></p><p> closedge[k].lowcost=0;</p><p> for(i=1;i<=G.vexnum;i++){</p>
76、<p> //for(k=1;k<=G.vexnum;k++)</p><p> //printf("(%d %d) %c",closedge[k].data,closedge[k].lowcost,k==G.vexnum?'\n':' ');</p><p><b> k=0; </b>
77、</p><p> for(j=1;j<=G.vexnum;j++){ //選出T的下一個(gè)結(jié)點(diǎn),第k個(gè)頂點(diǎn)</p><p> if(closedge[j].lowcost==0) continue;</p><p> if(k==0){k=j;continue;}</p><p> if(closedge[k].lowcos
78、t>closedge[j].lowcost) </p><p><b> k=j;</b></p><p><b> }</b></p><p> //for(int t=1;t<=G.vexnum;t++)</p><p> //printf("(%d %d %d%
79、c)\t",t,closedge[t].lowcost,closedge[t].j,t==G.vexnum?'\n':' ');</p><p> if(k)printf("(%c %c %d) ",G.vertices[closedge[k].j].data,G.vertices[k].data,closedge[k].lowcost); //最
80、小生成樹(shù)的頂點(diǎn)向量、值、及權(quán)</p><p> mincost+=closedge[k].lowcost;</p><p> closedge[k].lowcost=0;</p><p> for(j=1;j<=G.vexnum;j++)</p><p> if(G.arcs[j][k].adj<closedge[j].l
81、owcost){</p><p> closedge[j].data=G.vertices[j].data;</p><p> closedge[j].lowcost=G.arcs[j][k].adj;</p><p> closedge[j].j=k;</p><p><b> }</b></p>
82、<p> }printf("\n\t\t最小代價(jià)和為 :%d\n",mincost);</p><p><b> }</b></p><p> int TOpologicalSort(ALGraph & G)//拓?fù)渑判?lt;/p><p><b> {</b></p>
83、;<p> stack <int> S;</p><p> int i,j,count=0;</p><p> int indegree[30];</p><p> for(i=1;i<=G.vexnum;i++)</p><p> indegree[i]=G.vertices[i].indegree
84、;</p><p> if(G.kind==3||G.kind==4) {printf("無(wú)向圖不能進(jìn)行拓?fù)渑判騖n");return -1;}</p><p> printf("\n拓?fù)渑判颍?quot;);</p><p> for(i=1;i<=G.vexnum;i++)</p><p> i
85、f(G.vertices[i].indegree==0)S.push(i);</p><p> while(!S.empty()){</p><p> j=S.top(); S.pop();</p><p><b> count++;</b></p><p> printf("(%d %c) &quo
86、t;,j,G.vertices[j].data);</p><p> for(ArcNode *p=G.vertices[j].firstarc;p;p=p->nextarc){</p><p> int k=p->adjvex;</p><p> int d=--(G.vertices[k].indegree);</p><p
87、> if(!d)S.push(k);</p><p><b> }</b></p><p><b> }</b></p><p> for(i=1;i<=G.vexnum;i++)</p><p> G.vertices[i].indegree=indegree[i];<
88、/p><p> if(G.vexnum==count){printf("\n"); return 1;}</p><p> printf("失?。n");return 0;</p><p><b> } </b></p><p> void Choose(ALGraph
89、&G){</p><p> int choice=G.kind;</p><p> char str[30];</p><p><b> do{</b></p><p> system("cls");</p><p> printf("\n\n\t\
90、t▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\n");</p><p> printf("\t\t▌?wù)堖x擇操作:\t\t\t\t ▌\n");</p><p> printf("\t\t▌1、用鄰接矩陣遍歷\t4、廣度優(yōu)先搜索\t ▌\n\t\t▌2、用鄰接表遍歷\t5、拓?fù)渑判騖t ▌\n");</p><p>
91、; printf("\t\t▌3、深度優(yōu)先搜索\t6、最小生成樹(shù)\t ▌\n\t\t▌7、返回\t\t8、退出程序\t\t ▌\n");</p><p> printf("\t\t ▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲\n\n");</p><p> printf("\t\t請(qǐng)輸入你的選擇(1-7):");</p&
92、gt;<p><b> do{</b></p><p> memset(str,0,sizeof(str));</p><p> gets(str);</p><p> if(strlen(str)>1) choice=-1;</p><p> else if(str[0]<'
93、;1'||str[0]>'8') choice=-1;</p><p> else choice=str[0]-'0';</p><p> if(choice==-1) printf("\t\t輸入不合法,請(qǐng)重新輸入:");</p><p> else break;</p><
94、;p> }while(1);</p><p> switch(choice){</p><p> case 1: VisitDG_DN_UDG_UDN(G,0); break;</p><p> case 2: VisitDG_DN_UDG_UDN(G,1); break;</p><p> case 3: DFSTraver
95、se(G);break;</p><p> case 4: BFSTraverse(G); break;</p><p> case 5:TOpologicalSort(G); break;</p><p> case 6: MinSpanTree_PRIM(G,G.vertices[1].data);break;</p><p>
96、case 7:return;</p><p> case 8:exit(0);</p><p><b> }</b></p><p> printf("\n\t\t按回車鍵繼續(xù)....."); getchar();</p><p> }while(1);</p><p>
97、;<b> }</b></p><p> void Menu(ALGraph &G){</p><p> bool f=true;</p><p> int choice=-1;</p><p> char str[30];</p><p><b> do{</
98、b></p><p> system("cls");</p><p> printf("\n\n\t\t╔════════════════════╗\n");</p><p> printf("\t\t║\t\t\t\t\t ║\n");</p><p> print
99、f("\t\t║\t\t圖的建立與操作\t\t ║\n");</p><p> printf("\t\t║\t\t\t\t\t ║\n");</p><p> printf("\t\t╚════════════════════╝\n\n");</p><p> printf("\t\t請(qǐng)
100、選擇建圖方式:\n");</p><p> printf("\t\t\t1、有向圖\t2、有向網(wǎng)\n");</p><p> printf("\t\t\t3、無(wú)向圖\t4、無(wú)向網(wǎng)\n\t\t\t5、退出\n\n");</p><p> printf("\t\t請(qǐng)輸入你的選擇(1-5):");
101、</p><p><b> do{</b></p><p> memset(str,0,sizeof(str));</p><p> gets(str);</p><p> if(strlen(str)>1) choice=-1;</p><p> else if(str[0
102、]<'0'||str[0]>'9') choice=-1;</p><p> else choice=str[0]-'0';</p><p> if(choice<1||choice>5) </p><p> printf("\t\t你的輸入不合法,請(qǐng)重新輸入(1-5):&quo
103、t;);</p><p><b> else</b></p><p><b> break;</b></p><p> }while(1);</p><p> if(choice==5) break;</p><p><b> else{</
104、b></p><p> G.kind=choice;</p><p> CreateDG_DN_UDG_UDN(G);</p><p> system("cls");</p><p> printf("\n\n\n\n\t\t圖已建立,按回車鍵繼續(xù)其他操作...");</p>
105、<p> getchar();</p><p> Choose(G);</p><p><b> }</b></p><p> }while(1);</p><p><b> }</b></p><p> int main()</p>&
106、lt;p><b> {</b></p><p> ALGraph G;</p><p> printf("");</p><p><b> Menu(G); </b></p><p><b> return 0;</b></p>
107、<p><b> }</b></p><p><b> 七、運(yùn)行結(jié)果分析</b></p><p> 測(cè)試數(shù)據(jù)及運(yùn)行結(jié)果見(jiàn)以下截圖</p><p> 主界面的建立,可以自由選擇建立圖,輸入數(shù)據(jù)應(yīng)嚴(yán)格按照要求,否則,無(wú)法建立 </p><p> 鄰接矩陣的遍歷有邊輸出權(quán)值(對(duì)于網(wǎng))
108、或1(對(duì)于圖),無(wú)邊輸出無(wú)窮</p><p> 用鄰接表遍歷,依次輸出每個(gè)頂點(diǎn)的臨鄰接點(diǎn),并輸出本點(diǎn)的出度和入度</p><p> 以下四個(gè)截圖分別是深度優(yōu)先搜索、廣度優(yōu)先搜索、拓?fù)渑判蚝妥钚∩蓸?shù)的運(yùn)行結(jié)果,均用字符表示其遍歷或操作的順序</p><p><b> 其他測(cè)試數(shù)據(jù):</b></p><p><
109、b> 3</b></p><p><b> 5 8</b></p><p><b> ABCDE</b></p><p> D E 1 C E 1 D C 1 A E 1 B E 1 B A 1 A D 1 B C 1</p><p><b> 2
110、</b></p><p><b> 5 6</b></p><p><b> 12345</b></p><p> 1 2 1 1 3 1 2 3 1 4 5 1 5 2 1 4 3 1</p><p><b> 八、收獲及體會(huì)</b></p
111、><p> 在進(jìn)行這次課程設(shè)計(jì)的過(guò)程中,我真正學(xué)到了教科書上所沒(méi)有或者真正用到了課本上的知識(shí)。這樣,既鞏固了舊知識(shí),又掌握了新知識(shí)。所以,數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)是我們的重中之重,是提高我們專業(yè)知識(shí)與實(shí)踐相結(jié)合的重要手段。</p><p> 這次課程設(shè)計(jì),對(duì)我進(jìn)行了結(jié)構(gòu)化程序設(shè)計(jì)的初步訓(xùn)練,培養(yǎng)了我的數(shù)據(jù)抽象能力。在實(shí)際操作過(guò)程中,遇到很多問(wèn)題,通過(guò)查書,上網(wǎng)查資料,最后問(wèn)老師,把問(wèn)題解決,在這個(gè)
112、過(guò)程中,把課堂上的知識(shí)很好的運(yùn)用到實(shí)際上,還通過(guò)解決問(wèn)題,學(xué)習(xí)到很多課外知識(shí),引導(dǎo)和激發(fā)我對(duì)數(shù)據(jù)結(jié)構(gòu)的興趣,同時(shí)還要培養(yǎng)我搜索分析信息、查閱幫助文檔、整理經(jīng)驗(yàn)編寫文檔、合作交流的能力。</p><p> 課程設(shè)計(jì)中我遇見(jiàn)了一些難點(diǎn),比方說(shuō) 輸入數(shù)據(jù)時(shí)錯(cuò)誤的輸入可能就會(huì)讓程序崩潰,經(jīng)過(guò)仔細(xì)思考,查閱資料,請(qǐng)教同學(xué),最后都圓滿的解決當(dāng)然,這是我收獲比較大一點(diǎn)。除此之外,我覺(jué)得一個(gè)好程序不僅在于它的功能的實(shí)現(xiàn),更重要
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 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ì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---圖的建立與輸出
- 《圖的建立與遍歷》數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-----圖的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---圖的遍歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)及其應(yīng)用(算法與數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì))
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計(jì)
- 算法與數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論