版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
.../數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告班級(jí):姓名:學(xué)號(hào):目錄設(shè)計(jì)任務(wù)3設(shè)計(jì)時(shí)間3設(shè)計(jì)內(nèi)容31、需要分析32、概要設(shè)計(jì)33、詳細(xì)設(shè)計(jì)44、測(cè)試與分析9四、設(shè)計(jì)總結(jié)10源程序清單11一.設(shè)計(jì)任務(wù):我選課程設(shè)計(jì)是自選題目《圖的遍歷》。要求:設(shè)計(jì)一個(gè)程序,實(shí)現(xiàn)圖的廣度,深度優(yōu)先遍歷。二、設(shè)計(jì)時(shí)間2009三、設(shè)計(jì)內(nèi)容1、需求分析本題目需要解決的問(wèn)題是將一幅已知圖,對(duì)圖進(jìn)行遍歷,并完成:〔1輸出它的鄰接矩陣;〔2根據(jù)人工選擇進(jìn)行深度優(yōu)先搜索〔Depth_FirstSearch和廣度優(yōu)先搜索〔Breadth_FirstSearch,將搜索結(jié)果放入一隊(duì)列中;〔3將隊(duì)列中的搜索結(jié)果輸出。2、概要設(shè)計(jì):<1>抽象數(shù)據(jù)的類型定義數(shù)據(jù)對(duì)象:V是圖具有相同特性的數(shù)據(jù)元素的集合,稱為定頂點(diǎn)集數(shù)據(jù)關(guān)系:RR={VR}VR={<v,w>/v,w∈v且p<v,w>}基本操作:CreateGraph<&G,V,VR>初始條件:V是圖的頂點(diǎn)集,VR是圖中弧的集合操作結(jié)果:按V和VR的定義構(gòu)造圖G基本操作:DFSTraverse<G,Visit<>>BFSTraverse<G,Visit<>>〔2主程序的流程以及各程序模塊之間的調(diào)用關(guān)系:CreateGraph算法CreateGraph算法打印鄰接矩陣初始化成功選擇如何遍歷開(kāi)始深度優(yōu)先遍歷廣度優(yōu)先遍歷結(jié)束NYDB3、詳細(xì)設(shè)計(jì):〔1定義圖
typedef
struct{
intV[M];
intR[M][M];
intvexnum;
}Graph;〔2創(chuàng)建圖
voidcreatgraph<Graph*g,intn>
{
inti,j,r1,r2;
g->vexnum=n;
/*頂點(diǎn)用i表示*/
for<i=1;i<=n;i++>
{
g->V[i]=i;
}
/*初始化R*/
for<i=1;i<=n;i++>
for<j=1;j<=n;j++>
{
g->R[i][j]=0;
}
/*輸入R*/
printf<"PleaseinputR<0,0END>:\n">;
scanf<"%d,%d",&r1,&r2>;
while<r1!=0&&r2!=0>
{
g->R[r1][r2]=1;
g->R[r2][r1]=1;
scanf<"%d,%d",&r1,&r2>;
}
}〔3全局變量:訪問(wèn)標(biāo)志數(shù)組
voidprintgraph<Graph*g>
{
inti,j;
for<i=1;i<=g->vexnum;i++>
{for<j=1;j<=g->vexnum;j++>
{
printf<"%2d",g->R[i][j]>;
}
printf<"\n">;
}
}
〔4訪問(wèn)頂點(diǎn)
intvisited[M];
voidvisitvex<Graph*g,intvex>
{printf<"%d",g->V[vex]>;
}〔5獲取第一個(gè)未被訪問(wèn)的鄰接節(jié)點(diǎn)
intfirstadjvex<Graph*g,intvex>
{
intw,i;
for<i=1;i<=g->vexnum;i++>
{
if<g->R[vex][i]==1&&visited[i]==0>
{
w=i;
break;
}
else
{
w=0;
}
}
returnw;
}
/*獲取下一個(gè)未被訪問(wèn)的鄰接節(jié)點(diǎn)<深度遍歷>*/
intnextadjvex<Graph*g,intvex,intw>
{
intt;
t=firstadjvex<g,w>;
returnt;
}
〔6深度遞歸遍歷
voiddfs<Graph*g,int
vex>
{
int
w;
visited[vex]=1;
visitvex<g,vex>;
for<w=firstadjvex<g,vex>;w>0;w=nextadjvex<g,vex,w>>
if<!visited[w]>
{
dfs<g,w>;
}
}void
dfstraverse<Graph*g>
{
inti;
for<i=1;i<=g->vexnum;i++>
visited[i]=0;
for<i=1;i<=g->vexnum;i++>
if<!visited[i]>
{dfs<g,i>;}
}
〔7定義隊(duì)列
typedef
struct{
intV[M];
intfront;
intrear;
}Queue;
〔8初始化隊(duì)列
initqueue<Queue
*q>
{
q->front=0;
q->rear=0;
}
〔9判斷隊(duì)列是否為空
intquempty<Queue*q>
{
if<q->front==q->rear>
{
return0;
}
else
{
return1;
}
}
〔10入隊(duì)操作
enqueue<Queue*q,inte>
{
if<<q->rear+1>%M==q->front>
{
printf<"The
queueisoverflow!\n">;
return0;
}
else
{
q->V[q->rear]=e;
q->rear=<q->rear+1>%M;
return1;
}
}
〔11出隊(duì)操作
dequeue<Queue*q>
{
intt;
if<q->front==q->rear>
{
printf<"Thequeueisempty!\n">;
return0;
}
else
{
t=q->V[q->front];
q->front=<q->front+1>%M;
returnt;
}
}
〔12廣度遍歷
voidBESTraverse<Graph*g>
{
inti;
Queue
*q=<Queue*>malloc<sizeof<Queue>>;
for<i=1;i<=g->vexnum;i++>
{
visited[i]=0;
}
initqueue<q>;
for<i=1;i<=g->vexnum;i++>
{
if<!visited[i]>
{
visited[i]=1;
visitvex<g,g->V[i]>;
enqueue<q,g->V[i]>;
while<!quempty<q>>
{
intu,w;
u=dequeue<q>;
for<w=firstadjvex<g,u>;w>0;w=nextadjvex<g,u,w>>
{
if<!visited[w]>
{
visited[w]=1;
visitvex<g,w>;
enqueue<q,w>;
}
}
}
}
}
}4、測(cè)試與分析:針對(duì)下圖進(jìn)行測(cè)試和分析:112345678由圖已知有8個(gè)結(jié)點(diǎn),根據(jù)提示"Pleaseinputthenumberofvertex:"輸入"8"。再根據(jù)圖輸入鄰接矩陣中有關(guān)系的兩點(diǎn),兩點(diǎn)有關(guān)系只要輸入一次即可。當(dāng)輸入完所有關(guān)系后輸入"0,0"再輸入回車,程序?qū)⑤敵鲈搱D鄰接矩陣。再根據(jù)提示選擇"b","d"或"q"。選"b"表示廣度優(yōu)先搜索〔Breadth_FirstSearch,"d"表示深度優(yōu)先搜索〔Depth_FirstSearch,"q"表示退出。Pleaseinputthenumberthenumberofvertex:8PleaseinputR<0,0END>:1,22,44,85,82,51,33,63,70,0Thisisthelinjiejuzhenofgraph:0110000010011000100001100100000101000001001000000010000000011000Pleaseinputbordorq,Breadth_first:bDepth_first:dquit:qbBreadth_first:12345678Pleaseinputbordorq,Breadth_first:bDepth_first:dquit:qdDepth_fitst:12485367Pleaseinputbordorq,Breadth_first:bDepth_first:dquit:qqPressanykeytocontine運(yùn)行結(jié)果正確此程序可用四、設(shè)計(jì)總結(jié):圖的遍歷是程序設(shè)計(jì)語(yǔ)言編譯中的一個(gè)最基本問(wèn)題。"圖的遍歷"是數(shù)據(jù)結(jié)構(gòu)中主要的內(nèi)容之一,也是重要的內(nèi)容之一。它是樹(shù)的遍歷的拓展,但要比樹(shù)的遍歷復(fù)雜得多,是排序等的基礎(chǔ)。它運(yùn)用了深度優(yōu)先遍歷,廣度優(yōu)先遍歷,入隊(duì),出隊(duì)等多種運(yùn)算,很有意義,是對(duì)數(shù)據(jù)結(jié)構(gòu)一些基本操作的綜合應(yīng)用。在做設(shè)計(jì)的開(kāi)始就遇到了很多困難,比如,如何才能構(gòu)造鄰接矩陣,如何將鄰接矩陣表示出來(lái),如何將結(jié)果輸出,以及深度優(yōu)先搜索和廣度優(yōu)先搜索的用C語(yǔ)言表達(dá)等。在仔細(xì)研究教材尋找資料后,并和同學(xué)一同探討最終將困難解決。本次課程設(shè)計(jì)是學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)后的一次具體的實(shí)踐,體現(xiàn)了理論與實(shí)踐的有效結(jié)合。在實(shí)踐中體現(xiàn)出理論的思想,在實(shí)踐中深入了解理論的具體實(shí)質(zhì),在實(shí)踐中明白理論的精髓所在。同樣也很好地鍛煉了我自己動(dòng)手動(dòng)腦的的能力!附錄:源程序清單#define
M20
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
typedef
struct{
intV[M];
intR[M][M];
intvexnum;
}Graph;voidcreatgraph<Graph*g,intn>
{
inti,j,r1,r2;
g->vexnum=n;
/*頂點(diǎn)用i表示*/
for<i=1;i<=n;i++>
{
g->V[i]=i;
}
for<i=1;i<=n;i++>
for<j=1;j<=n;j++>
{
g->R[i][j]=0;
}
printf<"PleaseinputR<0,0END>:\n">;
scanf<"%d,%d",&r1,&r2>;
while<r1!=0&&r2!=0>
{
g->R[r1][r2]=1;
g->R[r2][r1]=1;
scanf<"%d,%d",&r1,&r2>;
}
}
voidprintgraph<Graph*g>
{
inti,j;
for<i=1;i<=g->vexnum;i++>
{for<j=1;j<=g->vexnum;j++>
{
printf<"%2d",g->R[i][j]>;
}
printf<"\n">;
}
}
intvisited[M];
voidvisitvex<Graph*g,intvex>
{
printf<"%d",g->V[vex]>;
}
intfirstadjvex<Graph*g,intvex>
{
intw,i;
for<i=1;i<=g->vexnum;i++>
{
if<g->R[vex][i]==1&&visited[i]==0>
{
w=i;
break;
}
else
{
w=0;
}
}
returnw;
}
intnextadjvex<Graph*g,intvex,intw>
{
intt;
t=firstadjvex<g,w>;
returnt;
}
voiddfs<Graph*g,int
vex>
{
int
w;
visited[vex]=1;
visitvex<g,vex>;
for<w=firstadjvex<g,vex>;w>0;w=nextadjvex<g,vex,w>>
if<!visited[w]>
{
dfs<g,w>;
}
}void
dfstraverse<Graph*g>
{
inti;
for<i=1;i<=g->vexnum;i++>
visited[i]=0;
for<i=1;i<=g->vexnum;i++>
if<!visited[i]>
{dfs<g,i>;}
}
typedef
struct{
intV[M];
intfront;
intrear;
}Queue;
initqueue<Queue
*q>
{
q->front=0;
q->rear=0;
}
intquempty<Queue*q>
{
if<q->front==q->rear>
{
return0;
}
else
{
return1;
}
}
enqueue<Queue*q,inte>
{
if<<q->rear+1>%M==q->front>
{
printf<"The
queueisoverflow!\n">;
return0;
}
else
{
q->V[q->rear]=e;
q->rear=<q->rear+1>%M;
return1;
}
}
dequeue<Queue*q>
{
intt;
if<q->front==q->rear>
{
printf<"Thequeueisempty!\n">;
return0;
}
else
{
t=q->V[q->front];
q->front=<q->front+1>%M;
returnt;
}
}
voidBESTraverse<Graph*g>
{
inti;
Queue
*q=<Queue*>malloc<sizeof<Queue>>;
for<i=1;i<=g->vexnum;i++>
{
visited[i]=0;
}
initqueue<q>;
for<i=1;i<=g->vexnum;i++>
{
if<!visited[i]>
{
visited[i]=1;
visitvex<g,g->V[i]>;
enqueue<q,g->V[i]>;
while<!quempty<q>>
{
intu,w;
u=dequeue<q>;
for<w=firstadjvex<g,u>;w>0;w=nextadjvex<g,u,w>>
{
if<!visited[w]>
{
visited[w]=1;
visitvex<g,w>;
en
溫馨提示
- 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ù)網(wǎng)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 房地產(chǎn)市場(chǎng)報(bào)告 -2024年四季度青島寫(xiě)字樓和零售市場(chǎng)報(bào)告
- 2025廣告公司采購(gòu)合同
- 2025食品代理合同樣本
- 二零二五年度數(shù)字貨幣內(nèi)部股東股權(quán)轉(zhuǎn)讓合同模板3篇
- 二零二五年度農(nóng)業(yè)機(jī)械設(shè)備租賃與農(nóng)產(chǎn)品加工服務(wù)合同3篇
- 2025年度鄉(xiāng)村振興戰(zhàn)略下全新貧困戶幫扶合作協(xié)議3篇
- 二零二五年度車輛維修版服務(wù)合同3篇
- 二零二五年度全新私人合同:私人健身俱樂(lè)部及健身器材租賃服務(wù)協(xié)議2篇
- 二零二五年度企業(yè)個(gè)人業(yè)績(jī)目標(biāo)對(duì)賭協(xié)議3篇
- 2025年度環(huán)保科技合伙人股權(quán)分配與綠色發(fā)展合同3篇
- GB/T 13203-2021摩托車輪胎性能試驗(yàn)方法
- GA/T 744-2013汽車車窗玻璃遮陽(yáng)膜
- 2022年杭州市建設(shè)行業(yè)職業(yè)技能競(jìng)賽裝配式建筑施工員賽項(xiàng)技術(shù)文件
- 急腹癥試題(單選、多選)
- 2022年部編版四年級(jí)道德與法治上冊(cè)全冊(cè)教案
- 廠房(鋼結(jié)構(gòu)框架)工程施工組織設(shè)計(jì)施工組織設(shè)計(jì)DOC
- 人教版新目標(biāo)九年級(jí)英語(yǔ)全冊(cè)教案
- 幼兒園教學(xué)課件——我是哥哥姐姐
- 國(guó)內(nèi)異形盾構(gòu)機(jī)分析課件
- 喚醒孩子內(nèi)驅(qū)力家校共育家庭教育PPT課件(帶內(nèi)容)
- 合成氣精脫硫催化劑的研究報(bào)告
評(píng)論
0/150
提交評(píng)論