




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
首页, 上一页, 下一页; 目录 第十三章图的遍历13.1基本概念解决了图的储存问题后,接下来的肯定就是解决如何去访问图上面的元素的问题了,也就是图的遍历。书里面对图的遍历是用深度优先搜索算法(Depth First Search,简称DFS)和广度优先搜索算法(Breadth First Search,简称BFS),其实说白了就是按照“分层”的思想来进行。深度优先就是先访问完最深层次的数据元素,广度优先就是先访问完同一层次的数据元素,它们的时间复杂度都是一样的,只是访问元素的顺序不同而已。13.2代码实现/ FileName : TraverseGraph.h/ Version : 0.10/ Author : Luo Cong/ Date : 2005-1-29 16:28:44/ Comment : /#ifndef _TRAVERSE_GRAPH_H_#define _TRAVERSE_GRAPH_H_#include ././ListGraph/src/ListGraph.h#include ././queue/src/lqueue.htemplateclass CTraverseGraph : public CListGraphprotected: int *m_nVisited;private: int InitializeVisited(const int n); void FinalizeVisited(); void DFS(const int n, void (*Visit)(const T_Vertex &vertex) const;public: void DFS(void (*Visit)(const T_Vertex &vertex); void BFS(void (*Visit)(const T_Vertex &vertex);templateinline int CTraverseGraph:InitializeVisited(const int n) int i; m_nVisited = new intn; if (NULL = m_nVisited) return 0; for (i = 0; i n; +i) m_nVisitedi = 0; return 1;templateinline void CTraverseGraph:FinalizeVisited() if (m_nVisited) delete m_nVisited; m_nVisited = NULL; templateinline void CTraverseGraph:DFS( const int n, void (*Visit)(const T_Vertex &vertex) const int i; int j = 0; int nRetCode; T_Vertex vertex; m_nVisitedn = 1; nRetCode = GetVertexAt(n, &vertex); if (0 = nRetCode) return ; Visit(vertex); i = GetFirstAdjVertexIndex(n); for (; i != -1; i = GetNextAdjVertexIndex(n, j+) if (!m_nVisitedi) DFS(i, Visit); templateinline void CTraverseGraph:DFS( void (*Visit)(const T_Vertex &vertex) int i; int nVertexNum; nVertexNum = GetVertexNum(); if (!InitializeVisited(nVertexNum) return ; for (i = 0; i nVertexNum; +i) if (!m_nVisitedi) DFS(i, Visit); FinalizeVisited();templateinline void CTraverseGraph:BFS( void (*Visit)(const T_Vertex &vertex) int i; int j; int k; int l; int nRetCode; int nVertexNum; T_Vertex vertex; CLQueue queue; nVertexNum = GetVertexNum(); if (!InitializeVisited(nVertexNum) return ; for (i = 0; i nVertexNum; +i) if (m_nVisitedi) continue; / visit vertexi m_nVisitedi = 1; nRetCode = GetVertexAt(i, &vertex); if (0 = nRetCode) return ; Visit(vertex); queue.EnQueue(i); / visit vertexis adjacency vertex(s) while (!queue.IsEmpty() j = queue.DeQueue(); / equal to i above k = GetFirstAdjVertexIndex(j); l = 0; / adjacency vertex(s): for (; k != -1; k = GetNextAdjVertexIndex(j, l+) if (!m_nVisitedk) m_nVisitedk = 1; nRetCode = GetVertexAt(k, &vertex); if (0 = nRetCode) return ; Visit(vertex); queue.EnQueue(k); FinalizeVisited();#endif / _TRAVERSE_GRAPH_H_测试代码:/ FileName : TraverseGraph.cpp/ Version : 0.10/ Author : Luo Cong/ Date : 2005-1-29 16:30:34/ Comment : /#include TraverseGraph.htypedef int ElementType;static void PrintVertex(const ElementType &vertex) cout V vertex ;int main() CTraverseGraph tgraph;#ifdef _DEBUG _CrtSetDbgFlag(_CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF);#endif / (1) / / / / / / / (2) (3) / / / / / / / (4) (5) (6)-(7) / / / / / (8) tgraph.InsertVertex(1); tgraph.InsertVertex(2); tgraph.InsertVertex(3); tgraph.InsertVertex(4); tgraph.InsertVertex(5); tgraph.InsertVertex(6); tgraph.InsertVertex(7); tgraph.InsertVertex(8); / 因为CListGraph是一个有向图类,所以这里为了创建一个无向图, / 必须把每条边从入边和出边两个方向分别创建一次: tgraph.InsertEdge(1, 2, 1); tgraph.InsertEdge(2, 1, 1); tgraph.InsertEdge(1, 3, 1); tgraph.InsertEdge(3, 1, 1); tgraph.InsertEdge(2, 4, 1); tgraph.InsertEdge(4, 2, 1); tgraph.InsertEdge(2, 5, 1); tgraph.InsertEdge(5, 2, 1); tgraph.InsertEdge(3, 6, 1); tgraph.InsertEdge(6, 3, 1); tgraph.InsertEdge(3, 7, 1); tgraph.InsertEdge(7, 3, 1); tgraph.InsertEdge(6, 7, 1); tgraph.InsertEdge(7, 6, 1); tgraph.InsertEdge(4, 8, 1); tgraph.InsertEdge(8, 4, 1); tgraph.InsertEdge(5, 8, 1); tgraph.InsertEdge(8, 5, 1); cout Graph is: endl; cout tgraph endl; cout DFS Traverse: endl; tgraph.DFS(PrintVertex); cout NULL endl endl; cout BFS Traverse: endl; tgraph.BFS(PrintVertex); cout NULL endl;13.3说明为了说明DFS和BFS,我另外写了一个类:CTraverseGraph,它继承于前面的邻接链表图类:CListGraph。
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 消防工程补充协议书
- 工业炉燃料系统装配工服务质量抽查考核试卷及答案
- 铁氧体材料烧成工服务响应速度考核试卷及答案
- 线上签协议书注意什么
- 2025版权委托代理服务合同
- 脚轮制作工安全警示标识认知考核试卷及答案
- 山东省济宁兖州区七校联考2026届八年级数学第一学期期末预测试题含解析
- 江苏省南京东山外国语学校2026届七年级数学第一学期期末综合测试试题含解析
- 2025年国有土地使用权转让合同(现状补办类)模板范文
- 山东东营市2026届数学八年级第一学期期末学业质量监测试题含解析
- 合肥市社会化工会工作者招聘考试真题2024
- 2025年安全员b证考试安徽省题库及答案解析
- 首台套申报培训课件
- GB/T 14193.1-2025液化气体气瓶充装规定第1部分:工业气瓶
- 保安安检培训课件
- 凯里市大风洞夸山重晶石矿场环评报告
- 2021基层2型糖尿病胰岛素应用专家共识(全文)
- 乳腺增生病讲座
- DG1022型双通道函数任意波形发生器
- 安全监理现场巡视检查记录表
- GB/T 9113.2-2000凹凸面整体钢制管法兰
评论
0/150
提交评论