实际场景中,对于某项工程中的各个任务以及完成它们的先后次序,我们经常用有向无环网(带权的有向无环图)来表示。
图 1 有向无环图
图 1 就是一张有向无环网,整张网表示一项工程,顶点 V1~V9 表示工程中的各个任务;弧 a1~a11 表示执行各个任务的先后次序,各个弧的权值表示完成各个任务所需要的时间。
类似上面这样,当我们用有向无环网描述某项工程时,数据结构中称这样的网结构为 AOE(Activity On Edge)网,网中的顶点称为“事件”,弧称为“活动”,弧对应的权值代表活动持续的时间。
在 AOE 网中,每个事件表示在它之前的活动已经完成,之后的活动可以开始。例如图 1 中,V5 表示 a4 和 a5 已经完成,a7 和 a8 可以开始。
通常情况下,AOE 网中只有一个开始顶点和一个结束顶点,比如图 1 表示的整个工程从 V1 开始,一直到 V9 结束。开始顶点就是入度为 0 的顶点,又称“源点”;结束顶点就是出度为 0 的顶点,又称“汇点”。
搞清楚事件、活动、源点、汇点这些词汇的含义之后,接下来的讲解中将使用它们。
再次观察图 1,对 a1->a4->a7->a10 和 a1->a4->a8-