




已阅读5页,还剩28页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
图的遍历,深度优先搜索,广度优先搜索,图的遍历,小结和作业,复习,课堂练习,图的遍历的应用举例(自学),复习-图的存储结构,复习-图的存储结构,复习-图的存储结构,复习-图的存储结构,图的遍历,定义:从图中某个顶点出发游历图,访遍图中其余顶点,并且使图中的每个顶点仅被访问一次的过程。,用途:是解决图的连通性、拓扑排序和求关键路径等算法的基础。,深度优先搜索,广度优先搜索,分类:,深度优先搜索,W1、W2和W3均为V的邻接点,SG1、SG2和SG3分别为含顶点W1、W2和W3的子图。,深度优先搜索,访问顶点V;for(W1、W2、W3)若邻接点Wi未被访问,则从它出发进行深度优先搜索遍历。,深度遍历序列:,V1V2V4V8V5,V6V3V7,V1,V2,V4,V5,V3,V7,V6,V8,深度优先搜索-连通图,1、从深度优先搜索遍历连通图的过程类似于树的先根遍历2、对图G深度优先搜索得到的顶点序列不是唯一的?3、搜索过程中经过的边和所有的顶点构成了图的一棵生成树。4、如何判别V的邻接点是否被访问?为每个顶点设立一个“访问标志visited”;,深度优先搜索-连通图,voidDFS(intv)/从顶点v出发,深度优先搜索遍历连通图/DFS,深度优先搜索-连通图,vertexsv.visited=true;,/对v的尚未访问的邻接顶点w递归调用DFS,for(w=firstAdjVex(v);w=0;w=nextAdjVex(v,w)if(vertexsw.visited=false)DFS(w);,V1,V2,V3,V4,V5,V1,V2,V8,V5,V6,V4,V2,V8,V8,V3,V1,V6,V7,V3,V8,DFS(G,V1),V7,深度优先搜索非连通图,首先将图中每个顶点的访问标志设为fasle,之后搜索图中每个顶点,如果未被访问,则以该顶点为起始点,进行深度优先搜索遍历,否则继续检查下一顶点。,V1,V2,V4,V5,V3,V7,V6,V8,深度遍历:,V1V2V4V8,V5,V3V6V7,深度优先搜索非连通图,深度优先搜索非连通图,voidDFSTraverse(intv)for(v=0;vw2,V-w8的路径长度为1;,V-w7,V-w3,V-w5的路径长度为2;,V-w6,V-w4的路径长度为3。,w1,w8,w3,w7,w6,w2,w5,w4,广度优先搜索,广度优先搜索,1.从图中的某个顶点V0出发,并在访问此顶点之后依次访问V0的所有未被访问过的邻接点,2.然后按这些顶点被访问的先后次序依次访问它们的邻接点,直至图中所有和V0有路径相通的顶点都被访问到。,3.若此时图中尚有顶点未被访问,则另选图中一个未曾被访问的顶点作起始点,4.重复上述过程,直至图中所有顶点都被访问到为止,广度优先搜索,V1,V8,广度遍历序列:,V4,V6,V8,V2,V5,V1,V3,V7,V2V3,V4V5V6V7,广度优先搜索,V1,V2,V4,V5,V3,V7,V6,V8,V1,V8,广度遍历序列:,V2V3,V4,V6V7,V5,publicvoidBFS()ArrayQueueAQueue=newArrayQueue();for(inti=0;i=0;w=nextAdjVex(u,w)if(vertexs(w).visited=false)System.out.print(vertexsw.data+”);vertexs(w).visited=true;AQueue.enQueue(w);/if/while/if,课堂练习,1:无向图G=(V,E),其中:V=a,b,c,d,e,f,E=(a,b),(a,e),(a,c),(b,e),(c,f),(f,d),(e,d),对该图进行深度优先遍历,得到的顶点序列正确的()。Aa,b,e,c,d,fBa,c,f,e,b,dCa,e,b,c,f,dDa,e,d,f,c,b,a,b,e,d,c,f,2:已知一无向图G=(V,E),其中V=a,b,c,d,eE=(a,b),(a,d),(a,c),(d,c),(b,e)现用某一种图遍历方法从顶点a开始遍历图,得到的序列为abecd,则采用的是_。,课堂练习,a,d,b,e,c,图的遍历应用举例,1.求一条从顶点i到顶点s的简单路径,2.求两个顶点之间的一条长度最短的路径,图的遍历应用举例,1.求一条从顶点i到顶点s的简单路径,求从顶点b到顶点k的一条简单路径。,从顶点b出发进行深度优先搜索遍历,图的遍历应用举例,求从顶点b到顶点k的一条简单路径。,假设找到的第一个邻接点是a,且得到的结点访问序列为:bachdekfg,假设找到的第一个邻接点是g,则得到的结点访问序列为:bgfkeadhc,图的遍历应用举例,1.从顶点i到顶点s,若存在路径,则从顶点i出发进行深度优先搜索,必能搜索到顶点s。,4.简单路径可能有多条。,3.由它出发进行的深度优先遍历已经完成的顶点不是路径上的顶点。,结论:,2.遍历过程中搜索到的顶点不一定是路径上的顶点。,图的遍历应用举例,voidDFSearch(intv,ints,char*PATH)/从第v个顶点出发递归地深度优先遍历图G,/求得一条从v到s的简单路径,并记录在PATH中vertexsv.visited=true;/访问第v个顶点for(w=FirstAdjVex(G,v);w=0;w=NextAdjVex(G,v,w)if(!Vertexsw.visited)DFSearch(w,s,PATH);,Append(PATH,getVertex(v);/第v个顶点加入路径,Append(PATH,w);else,if(!found)Delete(PATH);/从路径上删除顶点v,图的遍历应用举例,2.求两个顶点之间的一条长度最短的路径,若两个顶点之间存在多条路径,则其中必有一条路径长度最短的路径。如何求得这条路径?,图的遍历应用举例,求从顶点b到顶点k的一条路径长度最短的路径。,图的遍历应用举例,a,b,c,h,d,e,k,f,g,广度优先搜索访问
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 ISO 18618:2025 EN Dentistry - Interoperability of CAD/CAM systems
- 【正版授权】 IEC 63536:2025 EN-FR Railway applications - Signalling and control systems for non UGTMS urban rail systems
- 【正版授权】 IEC 60245-5:1994/AMD1:2003 EN-D Amendment 1 - Rubber insulated cables - Rated voltages up to and including 450/750 V - Part 5: Lift cables
- 北欧家装设计知识培训
- 校外骑车安全知识培训课件
- 校园预防偷窃安全知识培训课件
- 辩论修养试题及答案
- 电厂化学考试题及答案
- 北京面部护理知识培训班课件
- 校园安全知识培训教材课件
- 2024年数据泄露一次性赔偿合同
- 有害物质过程管理系统HSPM培训教材
- 乒乓球馆合伙人协议
- 2024至2030年中国品牌战略咨询服务市场现状研究分析与发展前景预测报告
- ISO∕TR 56004-2019创新管理评估-指南(雷泽佳译-2024)
- TSG+11-2020锅炉安全技术规程
- 从高考改卷谈对物理教学的几点启示
- DB32-T 4757-2024 连栋塑料薄膜温室建造技术规范
- 项目成本核算表模板
- 2024新版实习律师协议
- 2024辅警考试公基模拟220题及答案解析
评论
0/150
提交评论