拓扑排序

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

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

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

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

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

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

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

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

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

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

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

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

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

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


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值