数据结构第7章图.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

第七章图7.1图的类型定义7.2图的存储结构7.3图的遍历7.4最小生成树7.5有向无环图及其应用7.6最短路径

7.3图的遍历图的遍历:从图中某个顶点出发游历图,访遍图中其余顶点,并且使图中的每个顶点仅被访问一次的过程。在图中,访问部分顶点后,可能又沿着其他边回到已被访问过的顶点。为保证每一个顶点只被访问一次,必须对顶点进行标记,一般用一个辅助数组visit[0..n-1]作为对顶点的标记,当顶点vi未被访问,visit[i]值为0;当vi已被访问,则visit[i]值为1。通常,有两种遍历图的路径:深度优先搜索和广度优先搜索,对无向图和有向图都适用。

图的两种遍历方法:#2022

1.深度优先搜索DFSSTEP1STEP2STEP3STEP4选择图中某个(强)连通分量中某个顶点v出发:访问顶点v,并将其访问标记置为访问过,即visited[v]=1;依次从v的未被访问的邻接点出发,继续对图进行深度优先遍历,直到(强)连通分量中和v有路径相通的顶点都被访问过;如果图中还有顶点未被访问,则另选图中其余(强)连通分量中一个未被访问的顶点作起点,重复上述过程,直至图中所有顶点都被访问过为止。基本思想:

非连通图的每一个连通部分称为连通分量。连通分量:连通:在无向图中,如果从顶点v到顶点w有路径,则称v和w是连通的。LABMCFIDGJEHKDEIGHKLABMCFJ

(强)连通分量的遍历:W1、W2和W3均为V的邻接点。SG1为从W1出发可以访问到的顶点集;SG2为从W2出发可以访问到的顶点集;SG3为从W3出发可以访问到的顶点集。访问顺序:SG1?SG2?SG3。交集部分只访问一次。

abchdekfg812345670FFFFFFFFF012345678TTTTTTTTTachdkfebgachkfedbg访问标志:访问次序:例如:hk

voidDFSTraverse(GraphG){//深度优先遍历for(v=1;v=G.vexnum;++v)visited[v]=FALSE; //访问标志数组初始化for(v=1;v=G.vexnum;++v)if(!visited[v]) DFS(G,v,Visit);}voidDFS(GraphG,intv,Status(*Visit)(intv)){//从顶点v出发,深度优先搜索遍历连通分量visited[v]=TRUE;(*Visit)(v);//尚未访问的邻接顶点递归调用for(w=FirstAdjVex(G,v);w=0;w=NextAdjVex(G,v,w))if(!visited[w])DFS(G,w,Visit);}//DFS深度优先遍历的递归算法?

例1:深度优先遍历图G,并写出深度优先遍历序列。序列1:V1,V2,V4,V8,V5,V3,V6,V7序列2:V1,V2,V5,V8,V4,V3,V7,V6V1V2V4V5V3V7V6V8注意:由于没有规定访问邻接点的顺序,深度优先序列不是唯一的。

例2:深度优先遍历图G,并写出深度优先遍历序列。V1V2V4V5V3V7V6V8深度优先遍历序列:V1,V2,V4,V8,V5,V6,V3,V7V1,V2,V5,V8,V4,V6,V3,V7V1,V3,V7,V8,V6,V5,V2,V4

深度优先遍历序列??#2022

例3:已知图的邻接表如下,求从顶点0出发的深度优先遍历序列。深度优先遍历序列:0,1,2,3,4132120413204V0V1V2V3V401234V0V4V3V1V2深度优先遍历序列:0,1,2,3,40,1,2,4,30,1,4,2,30,3,2,1,40,3,2,4,1

添加标题0,1,3,4,2,5,6添加标题深度优先遍历序列:添加标题例4:已知图的邻接矩阵,求从顶点0出发的深度优先遍历序列。

0,1,2,3深度优先遍历序列:例5:已知图的邻接表如下,求从顶点0出发的深度优先遍历序列。

2.广度优先搜索BFS选择(强)连通分量中的某个顶点vi出发:访问顶点vi,并将其访问标志置为已被访问,即visited[vi]=1;访问vi的所

文档评论(0)

SYWL2019 + 关注
官方认证
文档贡献者

权威、专业、丰富

认证主体四川尚阅网络信息科技有限公司
IP属地四川
统一社会信用代码/组织机构代码
91510100MA6716HC2Y

1亿VIP精品文档

相关文档