


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上福建江夏學(xué)院數(shù)據(jù)結(jié)構(gòu)與關(guān)系數(shù)據(jù)庫(本科)實驗報告姓名 班級 學(xué)號 實驗日期 課程名稱 數(shù)據(jù)結(jié)構(gòu)與關(guān)系數(shù)據(jù)庫(本科) 指導(dǎo)教師 成績實驗名稱:深度優(yōu)先遍歷以鄰接表存儲的圖一、 實驗?zāi)康?、掌握以鄰接表存儲的圖的深度優(yōu)先遍歷算法;二、 實驗環(huán)境1、 硬件環(huán)境:微機2、 軟件環(huán)境: Windows XP,VC6.0三、實驗內(nèi)容、步驟及結(jié)果1、實驗內(nèi)容:基于圖的深度優(yōu)先遍歷編寫一個算法,判別以鄰接表方式存儲的有向圖中是否存在由頂點vi到頂點vj的路徑(ij)。 2、代碼:#include <stdio.h>#include <stdlib.h>#def
2、ine MaxVertexNum 100 /*最大頂點數(shù)為100*/typedef char VertexType;typedef struct node /*邊表結(jié)點*/int adjvex; /*鄰接點域*/struct node * next; /*指向下一個鄰接點的指針域*/*若要表示邊上信息,則應(yīng)增加一個數(shù)據(jù)域info*/EdgeNode;typedef struct vnode /*頂點表結(jié)點*/VertexType vertex; /*頂點域*/EdgeNode * firstedge; /*邊表頭指針*/VertexNode;typedef VertexNode AdjList
3、MaxVertexNum; /*AdjList 是鄰接表類型*/typedef structAdjList adjlist; /*鄰接表*/int n,e; /*頂點數(shù)和邊數(shù)*/ALGraph; /*ALGraph 是以鄰接表方式存儲的圖類型*/bool visitedMaxVertexNum;void CreateALGraph(ALGraph *G)/*建立有向圖的鄰接表存儲*/int i,j,k;EdgeNode * s;printf("請輸入頂點數(shù)和邊數(shù)(輸入格式為:頂點數(shù),邊數(shù)):n");scanf("%d,%d",&(G->n)
4、,&(G->e); /*讀入頂點數(shù)和邊數(shù)*/printf("請輸入頂點信息(輸入格式為:頂點號<CR>):n");for (i=0;i<G->n;i+) /*建立有n 個頂點的頂點表*/ scanf("n%c",&(G->adjlisti.vertex); /*讀入頂點信息*/G->adjlisti.firstedge=NULL; /*頂點的邊表頭指針設(shè)為空*/printf("請輸入邊的信息(輸入格式為:i,j):n");for (k=0;k<G->e;k+) /*
5、建立邊表*/ scanf("n%d,%d",&i,&j); /*讀入邊<Vi,Vj>的頂點對應(yīng)序號*/s=(EdgeNode*)malloc(sizeof(EdgeNode); /*生成新邊表結(jié)點s*/s->adjvex=j; /*鄰接點序號為j*/s->next=G->adjlisti.firstedge; /*將新邊表結(jié)點s 插入到頂點Vi 的邊表頭部*/G->adjlisti.firstedge=s;/*CreateALGraph*/void DFSAL(ALGraph *G,int i)/*以Vi 為出發(fā)點對鄰接表
6、存儲的圖G 進行DFS 搜索*/EdgeNode *p;printf("visit vertex:V%cn",G->adjlisti.vertex);/*訪問頂點Vi*/visitedi=true; /*標(biāo)記Vi 已訪問*/p=G->adjlisti.firstedge; /*取Vi 邊表的頭指針*/while(p) /*依次搜索Vi 的鄰接點Vj,j=p->adjva*/if (!visitedp->adjvex) /*若Vj 尚未訪問,則以Vj 為出發(fā)點向縱深搜索*/DFSAL(G,p->adjvex);p=p->next; /*找Vi 的下一個鄰接點*/*DFSAL*/void DFSTraverseAL(ALGraph *G)/*深度優(yōu)先遍歷以鄰接表存儲的圖G*/int i;for (i=0;i<G->n;i+)visitedi=false; /*標(biāo)志向量初始化*/for (i=0;i<G->n;i+)if (!visitedi) DFSAL(G,i); /*vi 未訪問過,從vi 開始DFS 搜索*/*DFSTraveseAL*/void main() ALGraph *G;G=(ALGraph *)malloc(sizeof(ALGraph); CreateALGrap
溫馨提示
- 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年月餅項目規(guī)劃申請報告模板
- 2025年IC卡鑒別機項目申請報告
- 【深圳】2025年廣東深圳技師學(xué)院選聘事業(yè)編制工作人員24人筆試歷年典型考題及考點剖析附帶答案詳解
- 文庫發(fā)布:人工智能
- 歐體教學(xué)課件
- 整體護理服務(wù)課件
- 七年級教學(xué)課件風(fēng)格分類
- 盼教學(xué)課件一等獎部編版
- 云南省昆明市官渡區(qū)2019年初中道德與法治學(xué)業(yè)水平考試第一次模擬測試試卷
- 懷念母親教學(xué)課件
- GB/T 5267.2-2002緊固件非電解鋅片涂層
- GB/T 12241-2021安全閥一般要求
- 第八組盲人輔助器具產(chǎn)品
- 2022年深圳電大地域文化(專)第一次作業(yè)
- SY∕T 7298-2016 陸上石油天然氣開采鉆井廢物處置污染控制技術(shù)要求
- TSG-R0005-2022《移動式壓力容器安全技術(shù)監(jiān)察規(guī)程》(2022版)
- (完整版)UPS技術(shù)培訓(xùn)教材PPT(共-54張)課件
- 全國醫(yī)療服務(wù)價格項目規(guī)范(試行)
- 食品用塑料包裝容器工具等制品生產(chǎn)許可審查細則
- 財政部金融企業(yè)不良資產(chǎn)批量轉(zhuǎn)讓管理辦法(財金[2012]6號)
- 格賓擋墻結(jié)構(gòu)設(shè)計計算書
評論
0/150
提交評論