数据结构-图的遍历_第1页
数据结构-图的遍历_第2页
数据结构-图的遍历_第3页
数据结构-图的遍历_第4页
数据结构-图的遍历_第5页
已阅读5页,还剩45页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、遍历图形,深度优先搜索,宽度优先搜索,遍历图形,摘要和任务,回顾,课堂练习,审查-图形的存储结构,审查-图形的存储结构,审查-图形的存储结构,审查-图形的存储结构,审查-图形的存储结构,审查-图形的存储结构,审查-图形的存储结构可以使用UDN交叉表的相邻矩阵dg和DN相邻多连接表可以用于udg和UDN的范围、复盖范围、存储结构比较、相邻矩阵3360 n N2相邻表可以用于DG和dn: n e或n 2e。 UDG和udn: n 2e交叉链路表: n e相邻多链路表: n e,第二,存储空间,存储结构比较,第三,作业支持,1,顶点访问,LocateVex(G,u);/u的位置,返回GetVex(G

2、,v)。/v的值。将值指定给PutVex(/u)。比较存储结构,2,插入和删除存储顶点阵列元素,修改相邻矩阵和相邻矩阵,将新顶点v添加到InsertVex(/地物g)。DeleteVex(/g)删除顶点v和相关圆弧。比较存储结构,3,插入和删除圆弧,InsertArc(,DeleteArc(,存储结构比较,相邻矩阵:修改边(和)相邻表:无图,修改两个顶点的连接表;修改具有一个或两个顶点的连接列表交叉列表:包含两个连接列表多个相邻列表:包含两个连接列表,比较存储结构,4,相邻点,第一个adjvex (g,v);/返回v的“第一个相邻点”。如果相应的顶点/g没有相邻点,则返回“空”。NextAdj

3、Vex(G,v,w);/v的(相对于w)返回“下一个相邻/点”。如果w是v的最后一个相邻点,则返回/null。存储结构比较,相邻矩阵:v行相邻列表:v行相交列表:v行相交列表:v行相邻列表:v行相邻列表:v行相邻列表,存储结构比较,相邻矩阵:v行相邻列表:v行相邻列表:v行相邻列表:v行相邻列表:v行相邻列表,4,相邻角,v行相邻列表/将第一个相邻点的位置返回为-1,没有相邻点。NextAdjVex(G,v,w);/w返回相邻点的位置。实现相邻点函数,int first adjvex (algragh g,int v)p=g . vertices v . firstarc;/v的第一个相邻点i

4、f(!p)return-1;/无相邻点return p-adj vex;实现相邻点函数,int next adjvex (algragh g,int v,int w)p=g . vertices v . firstarc;/v的第一个相邻点while(p,c语言中存储结构说明,1,插图中的两个参数:顶点数、边数(圆弧数)、vertices、vexnum、Edge(arc)、arc,用途:解决方案的连接性、拓扑排序和关键路径查找等算法的基础。深度优先搜索,宽度优先搜索,分类:深度优先搜索,W1、W2和W3都是v的相邻点,SG1、SG2和SG3分别是包含顶点W1、W2和W3的子图形。深度优先搜索,

5、访问顶点v;如果未访问For (W1、W2、W3)相邻点Wi,则将从该点开始深入搜索日历。深度优先搜索-连接图形,深度遍历序列:v1 v2 V8 V5,V6 v3 V7,v1,v2,v4,V5,v3,V7,V6,3、搜索过程中通过的边和所有顶点构成地物的一个延伸树。如何知道4,v的相邻点是否被访问?为每个顶点设置访问符号visitedw。深度优先搜索-连接图形,void DFS(Graph G,int v) /顶点v开始,深度优先搜索通过连接图形G visitedv=TRUEFor(w=FirstAdjVex(G,v);w=0;W=NextAdjVex(G,v,w)if(!Visitedw)

6、DFS(G,w);/v未访问的相邻顶点w DFS /DFS递归调用,深度优先搜索-连接图,void从DFS(Graph G,int v) /顶点v开始,深度优先搜索遍历连接图G visitedv=TRUEFor(w=FirstAdjVex(G,v);w=0;W=NextAdjVex(G,v,w)if(!Visitedw) DFS(G,w);/v尚未访问的相邻顶点w包括DFS /DFS、深度优先搜索-连接图、v1、v2、v3、v4、V5、v1、v2、V8、V5、V5Visited=FALSE/所有顶点尚未访问Push(S,v)。While(!empty(S)Pop(S,u);If(!Visitedu) visit (u),visitedu=trueFor(w=FirstAdjVex(G,u);w=0;W=NextAdjVex(G,u,w)if(!Visiitedw) push (g,w)/将未访问的相邻点堆叠DestroyS

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论