有向无环图的应用—AOV网 和 拓扑排序

简介: 有向无环图:无环的有向图,简称 DAG (Directed Acycline Graph) 图。 一个有向图的生成树是一个有向树,一个非连通有向图的若干强连通分量生成若干有向树,这些有向数形成生成森林。 在工程计划和管理方面的应用 除最简单的情况之外,几乎所有的工程都可分为若干

有向无环图:无环的有向图,简称 DAG (Directed Acycline Graph) 图。

一个有向图的生成树是一个有向树,一个非连通有向图的若干强连通分量生成若干有向树,这些有向数形成生成森林。

在工程计划和管理方面的应用

除最简单的情况之外,几乎所有的工程都可分为若干个称作“活动”的子工程,并且这些子工程之间通常受着一定条件的约束,例如:其中某些子工程必须在另一些子工

程完成之后才能开始。对整个工程和系统,人们关心的是两方面的问题:

一是工程能否顺利进行,即工程流程是否“合理”;

二是完成整个工程所必须的最短时间。

对应到有向图即为进行拓扑排序(AOV网)和求关键路径(AOE网)。 

拓扑排序

AOV 网:用一个有向图表示一个工程的各子工程及其相互制约的关系,其中以顶点表示活动,弧表示活动之间的优先制约关系,称这种有向图为顶点表示活动的网,简称AOV (Activity On  Vertex network)网。

比如、某工程可分为7个子工程(V0、V1、V2、V3、V4、V5、V6),若用顶点表示子工程(也称活动),用弧表示子工程间的顺序关系,工程流程可用如下的AOV网表示。

比如排课表

AOV 网的特点:若从 i 到 j 有一条有向路径,则 i是 j 的前驱;j 是 i 的后继。若 < i , j > 是网中有向边,则 i 是 j 的直接前驱; j 是 i 的直接后继。AOV 网中不允许有回路,因为如果有回路存在,则表明某项活动以自己为先决条件,显然这是荒谬的。

问题:如何判别 AOV 网中是否存在回路?即如何AOV网表示的工程能顺利进行?合理?

拓扑排序:

在 AOV 网没有回路的前提下,我们将全部活动排列成一个线性序,使得若 AOV 网中有弧 <i,  j> 存在,则在这个序列中, i  一定排在  j的前面,具有这种性质的线性序列称为拓扑有序序列,相应的拓扑有序排序的算法称为拓扑排序。

注意:

1、若将图中顶点按拓扑次序排成一行,则图中所有的有向边均是从左指向右的。
2、若图中存在有向环,则不可能使顶点满足拓扑次序。
3、一个DAG可能存在多个拓扑序列。

检测 AOV 网中是否存在环方法:

DFS( 深度优先搜索),出现返回边则有环; 拓扑排序,若所有的顶点都出现在拓扑排序中,则不出现环。如果使用 DFS 进行拓扑排序,那么结果是逆向的拓扑排序有序序列。 
拓扑排序方法:
1)在有向图中选一个无前趋的顶点v,输出之;
2)从有向图中删除v及以v为尾的弧;

3)重复1)、2),直接全部输出全部顶点或有向图中不存在无前趋的结点时为止。

删除 v2,v3,v4,v5,v6以及以他们为尾部的弧 

注意:一个AOV网的拓扑序列不是唯一的

 

辛苦的劳动,转载请注明出处,谢谢……
http://www.cnblogs.com/kubixuesheng/p/4404004.html
相关文章
|
4月前
拓扑排序
拓扑排序
22 0
|
4月前
|
NoSQL 容器 消息中间件
图、图的遍历及图的拓扑排序
图、图的遍历及图的拓扑排序
|
5月前
|
存储 人工智能 算法
【算法总结】拓扑排序
【算法总结】拓扑排序
32 0
|
8月前
我们来看看拓扑排序
我们来看看拓扑排序
|
10月前
|
搜索推荐
|
人工智能 自然语言处理 搜索推荐
拓扑排序算法
拓扑排序算法
92 0
|
存储 算法 搜索推荐
C++实现图 - 05 拓扑排序
今天来讲另一个非常重要的知识点 —— 拓扑排序。咋一看好像是一个排序算法,然而它和排序扯不上半点关系,它可以用于判断我们的图中是否存在有向环。
438 0
C++实现图 - 05 拓扑排序
|
人工智能 BI
[Nowcoder] 有向无环图 | 拓扑排序简单应用
题目描述 Bobo 有一个 n 个点,m 条边的 有向无环图 (即对于任意点 v,不存在从点 v 开始、点 v 结束的路径)。 为了方便,点用 1 , 2 , … , n编号。 设count(x,y) 表示点 x 到点 y 不同的路径数量(规定count(x,x)=0,Bobo 想知道 ∑i=1n∑j=1ncount(i,j)⋅ai⋅bj 除以( 1 0 9 + 7 ) 的余数。 其中,a i , b j 是给定的数列。
108 0
拓扑排序-Kitchen Plates
J. Kitchen Plates time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard output
89 0
拓扑排序-Kitchen Plates