图--拓扑排序课件.ppt

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
图--拓扑排序课件.ppt

* 6.1 图的基本术语 6.2 图的存储结构 6.3 图的遍历 6.4 最小生成树 6.5 最短路径 6.6 拓扑排序 6.7 关键路径 第6章 图 6.6 拓扑排序 AOV网 拓扑排序 关键路径 AOE网 6.6 拓扑排序 网中的顶点表示各门课程的教学活动,有向边表示各门课程的制约关系。 课程代号 课程名称 先修课程 0 高等数学 无 1 程序设计基础 无 2 C程序设计 0,1 3 离散数学 0 4 数据结构 1,2,3 5 编译方法 3,4 6 操作系统 4 0 1 2 3 4 5 6 6.6.1 AOV网 在有向图中若以顶点表示活动,用有向边表示活动之间的优先关系,则这样的有向图称为以顶点表示活动的网(Activity On Vertex Network),简称AOV网。 6.6 拓扑排序 应用: 工程流程、生产过程中各道工序的流程、程序流程、课程的流程 例如:某工程可分为V0、V1、V2、V3、V4、V5、V6,7个子工程,工程流程可用如下AOV网表示。其中顶点:表示子工程(也称活动),有向边:表示子工程间的顺序关系。 V5 V3 V2 V0 V1 V4 V6 6.6.1 AOV网 假设下图表示一个工程的施工图,判断该工程是否合理? V0 V1 V5 V2 V4 V3 V0 V1 6.6 拓扑排序 对工程,人们关心的问题: 工程能否顺序进行,即工程流程是否“合理” ? 能否给出一个活动之间的优先关系的有序序列? 拓扑排序:构造拓扑有序序列的过程。 一个AOV网的拓扑有序序列并不是惟一的。 6.6.2 拓扑排序 何谓“拓扑有序序列”? 它是由AOV网中的所有顶点构成的一个线性序列,在这个序列中体现了所有顶点间的优先关系。 对于某个AOV网, 如果它的拓扑有序序列被构造成功,则该网中不存在有向回路,其各子工程可按拓扑有序序列的次序进行安排。 V0 V1 V5 V2 V4 V3 V0 V1 【例如】:对于下列有向图 B D A C 可求得拓扑有序序列: A B C D 或 A C B D B D A C 不能求得它的拓扑有序序列。 因为图中存在一个回路 {B, C, D} 6.6.2 拓扑排序 如何进行拓扑排序? 1)从有向图中选取一个没有前驱的顶点,并输出之; 重复上述两步,直至图空,或者图不空但找不到无前驱的顶点为止。 2)从有向图中删去此顶点以及所有以它为尾的弧; 【注意】 这样操作后的结果有两种: 一种是网中全部顶点均被输出,说明网中不存在有向回路; 另一种是网中顶点未被全部输出,剩余的顶点均有前驱顶点,说明网中存在有向回路。 [拓扑排序的步骤] 6.6.2 拓扑排序 V0 V5 V2 V0 V1 V1 V3 V4 a b c g h d f e a b h c d g f e 【实例】--写出下图的拓扑排序序列 序列: 【练习】 写出表示课程以及课程的制约关系的AOV网的一个拓扑有序序列。 课程代号 课程名称 先修课程 0 高等数学 无 1 程序设计基础 无 2 C程序设计 0,1 3 离散数学 0 4 数据结构 1,2,3 5 编译方法 3,4 6 操作系统 4 0 1 2 3 4 5 6 【练习】 写出下图所示网所有可能的拓扑有序序列。 【练习答案】 写出下图所示网所有可能的拓扑有序序列。 可能的拓扑有序序列有: v1,v2,v3 ,v4,v5 ,v6 ; v1,v2,v3 ,v5,v4 ,v6 ; v1,v2,v4,v3 ,v5 ,v6 ; v2,v1,v4,v3 ,v5 ,v6 ; v2,v1,v3,v4 ,v5 ,v6 ; v2,v1,v3,v5 ,v4 ,v6 ; v2,v4,v1,v3 ,v5 ,v6 ; *

文档评论(0)

huaz15718 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档