【数据结构大题】拓扑排序与逆拓扑排序

文章介绍了拓扑排序和逆拓扑排序的概念,它们在有向无环图中的应用,以及执行步骤。拓扑排序按照入度为0的顶点顺序输出,而逆拓扑排序则按出度为0的顶点顺序进行。两者都能确保图中边的关系得到正确排序,但顺序可能不唯一。
摘要由CSDN通过智能技术生成

数据结构里面碰到的大题,拓扑排序与逆拓扑排序。这个题也比较常见,经常会考,也比较简单。

拓扑排序

对一个有向无环图G进行拓扑排序,是将G中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若边<u,v>∈E(G),则u在线性序列中出现在v之前。通常,这样的线性序列称为满足拓扑次序的序列,简称拓扑序列。(定义来自百度百科)

由AOV网构造出拓扑序列的实际意义是:如果按照拓扑序列中的顶点次序,在开始每一项活动时,能够保证它的所有前驱活动都已完成,从而使整个工程顺序进行,不会出现冲突的情况。(定义来自百度百科)

执行步骤

循环执行以下两步,直到不存在入度为0的顶点。

(1) 选择一个入度为0的顶点并输出。

(2) 从网中删除此顶点及所有出边。

(3) 循环(1)(2)

循环结束后,若输出的顶点数小于网中的顶点数,则输出“有回路”信息,否则输出的顶点序列就是一种拓扑序列。

具体例子

在这里插入图片描述
1 这个结点,入度为零,输入1这个结点。
然后删除结点1,以及结点1所连接的边。

在这里插入图片描述

2 这个结点,入度为零,输入2这个结点。
然后删除结点2,以及结点2所连接的边。

在这里插入图片描述
4 这个结点,入度为零,输入4这个结点。
然后删除结点4,以及结点4所连接的边。
在这里插入图片描述
3 这个结点,入度为零,输入3这个结点。
然后删除结点3,以及结点3所连接的边。
在这里插入图片描述
只剩下结点5了,

拓扑排序的序列为:12435

逆拓扑排序

逆拓扑排序是依次输出出度为0的顶点。与拓扑排序一样,输出不唯一。

执行步骤

1、从有向图中选择一个出度为0的顶点输出。

2、删除1中的顶点,并且删除指向该顶点的全部边。

3、重复上述两步,直到剩余的图中不存在出度为0的顶点为止。

具体例子

在这里插入图片描述
结点5出度为0,输出,删除结点5所在的边
在这里插入图片描述

结点3出度为0,输出,删除结点3所在的边

在这里插入图片描述
结点4出度为0,输出,删除结点4所在的边

在这里插入图片描述
结点2出度为0,输出,删除结点2所在的边

在这里插入图片描述
只剩下结点1,输出

逆拓扑排序的序列为:53421

作者:只识闲人不识君
日期:2022.04.10

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值