拓扑排序

什么是拓扑排序?简单的说,就是由某个集合上的一个偏序序列得到该集合上的一个全序序列,这个操作称之为拓扑排序。

那么,我们首先来回顾一下离散数学中的关于偏序和全序的定义:

若集合X上的关系R是自反的,反对称的和传递的,则称R是集合X上的偏序关系。

设R是集合X上的pain徐,如果对每个x,y输入X,必有xRy或者yRx,则称R是集合X上的全序关系。

举个简单的例子说明什么是拓扑排序。

现在到大学了,作为计算机系的学生,要学习很多与计算机相关的课程:有c语言,c++,java,数据结构,离散数学,线性代数,高等数学,编译原理,操作系统,组成原理,软件工程等等。。。

但是,如果你要学习数据结构,你就必须有离散数学和C语言的功底,那么在安排教学顺序时,就必须保证C语言和离散数学要学完再开数据结构。

还有一类,比如高等数学,它与数据结构没有关系,但是和线性代数有关系,这时,我们需要独立考虑高等数学,而不需要考虑C语言和离散数学。

以此类推,我们可以得到一张图。途中的关系就代表了教学的顺序。

那么,如何进行拓扑排序呢?很简单

1.在有向图中选一个没有前驱的项目且输出之。

2.从途中删除该顶点和所有以它为尾的弧。

3.重复上述两个步骤,直到全部顶点均已输出,或者当前图中不存在无前驱的顶点位置。后一种情况则说明有向图中存在环。在AOV-网中,不应该出现有向环,因为存在环就意味着某项活动以自己发生作为发生的条件,显然是很荒谬的。

之后,我们便完成了拓扑排序,拓扑排序可能有多个排序序列,我们只需要挑出满足题意的那种就可以了。。。


你可能感兴趣的:(java,数据结构,c,活动,语言)