#include#defineMaxNode40#defineM20typedefstructArcNode{intadjvex;str">
為圖建立鄰接表,深度與廣度遍歷

為圖建立鄰接表,深度與廣度遍歷

ID:11058040

大?。?7.00 KB

頁數(shù):4頁

時(shí)間:2018-07-09

為圖建立鄰接表,深度與廣度遍歷_第1頁
為圖建立鄰接表,深度與廣度遍歷_第2頁
為圖建立鄰接表,深度與廣度遍歷_第3頁
為圖建立鄰接表,深度與廣度遍歷_第4頁
資源描述:

《為圖建立鄰接表,深度與廣度遍歷》由會員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫。

1、為一個(gè)圖建立一個(gè)鄰接表、編寫深度遍歷和廣度遍歷算法#include#include#defineMaxNode40#defineM20typedefstructArcNode{intadjvex;structArcNode*nextarc;}ArcNode;typedefstruct{intvertex;structArcNode*firstarc;}vernode;typedefvernodeadjlist[MaxNode];intqueue[MaxNode];//在遍歷過程中是從右邊開始voiddfs

2、(adjlistg,intk,intvisited[])//從頂點(diǎn)k出發(fā),深度優(yōu)先搜索{ArcNode*p;intw;visited[k]=1;printf("%d->",g[k].vertex);p=g[k].firstarc;while(p!=NULL){w=p->adjvex;if(visited[w]==0)dfs(g,w,visited);p=p->nextarc;}}voidbfs(adjlistg,intk,intvisited[])//從頂點(diǎn)k出發(fā),廣度優(yōu)先搜索{intfront=0,rear=1,w;ArcNode*p;vi

3、sited[k]=1;//訪問初始頂點(diǎn)printf("%d->",k);queue[rear]=k;//初始頂點(diǎn)入隊(duì)列while(front!=rear)//隊(duì)列不為空{(diào)front=(front+1)%M;w=queue[front];//按訪問次序依次出隊(duì)列p=g[w].firstarc;while(p!=NULL){if(visited[p->adjvex]==0){visited[p->adjvex]=1;printf("%d->",p->adjvex);rear=(rear+1)%M;queue[rear]=p->adjvex;;}p

4、=p->nextarc;}}}voidtrave_bfs(adjlistg,intn){inti,visited[MaxNode];//數(shù)組visited標(biāo)志圖中的頂點(diǎn)是否已被訪問for(i=1;i<=n;i++)visited[i]=0;for(i=1;i<=n;i++)if(visited[i]==0)bfs(g,i,visited);printf("bb");}voidtrave_dfs(adjlistg,intn){inti,visited[MaxNode];//數(shù)組visited標(biāo)志圖中的頂點(diǎn)是否已被訪問for(i=1;i<

5、=n;i++)visited[i]=0;for(i=1;i<=n;i++)if(visited[i]==0)dfs(g,i,visited);printf("bb");}voidprint(adjlistg,intn){ArcNode*q;inti;printf("輸出無向圖的鄰接鏈表示:");for(i=1;i<=n;i++){printf("t%dt",i);printf("%d->",g[i].vertex);q=g[i].firstarc;while(q!=NULL){printf("%d->",q->adjvex);

6、q=q->nextarc;}printf("bb");}}voidmain(){ArcNode*p,*q;adjlistg;inti,j,n,k,e;printf("輸入圖中頂點(diǎn)的個(gè)數(shù),邊數(shù):");scanf("%d%d",&n,&e);for(k=1;k<=n;k++){getchar();printf("t第%d個(gè)頂點(diǎn)信息:",k);scanf("%d",&g[k].vertex);g[k].firstarc=NULL;//對順序存儲部分初始化}for(k=1;k<=e;k++){printf("第%d條邊的起點(diǎn),終點(diǎn):",k)

7、;scanf("%d%d",&i,&j);q=(ArcNode*)malloc(sizeof(ArcNode));q->adjvex=j;q->nextarc=g[i].firstarc;g[i].firstarc=q;p=(ArcNode*)malloc(sizeof(ArcNode));p->adjvex=i;p->nextarc=g[j].firstarc;g[j].firstarc=p;}print(g,n);printf("");printf("圖的深度優(yōu)先搜索:");trave_dfs(g,n);printf("");pr

8、intf("圖的廣度優(yōu)先搜索:");trave_bfs(g,n);printf("");

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動畫的文件,查看預(yù)覽時(shí)可能會顯示錯(cuò)亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負(fù)責(zé)整理代發(fā)布。如果您對本文檔版權(quán)有爭議請及時(shí)聯(lián)系客服。
3. 下載前請仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動等原因無法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請聯(lián)系客服處理。