


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上福建江夏學院數(shù)據(jù)結(jié)構(gòu)與關(guān)系數(shù)據(jù)庫(本科)實驗報告姓名 班級 學號 實驗日期 課程名稱 數(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; /*標記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; /*標志向量初始化*/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)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年安全評價師(高級)職業(yè)技能鑒定案例分析解析冊
- 2025年消防執(zhí)業(yè)資格考試題庫:消防應(yīng)急救援戰(zhàn)例分析實戰(zhàn)演練試卷
- 2025年美術(shù)教師編制考試模擬試卷:美術(shù)教育心理學研究與應(yīng)用試題
- 2025年CPE考試試卷:寫作思路引導(dǎo)與2025年考試熱點話題分析
- 語文課上難忘的一件事周記(13篇)
- 2025年輕油蒸汽轉(zhuǎn)化催化劑項目提案報告
- 2025年草除靈乙酯項目申請報告
- 2025年一建考試機電工程經(jīng)濟與造價管理實戰(zhàn)案例分析試題卷
- 2025年物業(yè)管理師考試物業(yè)管理物業(yè)設(shè)施運行管理實施改進報告反思試卷
- 在閱讀中發(fā)現(xiàn)美好閱讀感悟作文8篇
- 超星爾雅學習通《形勢與政策》2025春章節(jié)測試附答案
- 廣東省廣州市越秀區(qū)2025年中考一模歷史模擬試題(含答案)
- 有效咳嗽訓練操作流程
- 小學古詩文教育的創(chuàng)新教學方法與實踐
- 消防安裝抗震支架施工方案
- 財務(wù)合規(guī)培訓課件
- 云南xx城鎮(zhèn)老舊小區(qū)改造項目可行性研究報告
- 企業(yè)內(nèi)部停車位分配方案
- 湖南省長沙市雅禮實驗高中-主題班會-把學習變?yōu)闊釔郏簝?nèi)驅(qū)力【課件】
- 2025年中考英語總復(fù)習:補全對話 練習題匯編(含答案解析)
- 醫(yī)學細胞生物學(溫州醫(yī)科大學)知到智慧樹章節(jié)答案
評論
0/150
提交評論