(十七)拓扑排序算法

本文详细介绍了拓扑排序的概念和实现过程,包括使用邻接表和入度数组来辅助排序,并重点讲解了如何处理入度为0的节点。此外,还提供了LeetCode 207课程表问题作为拓扑排序的应用实例。
摘要由CSDN通过智能技术生成

在代码具体实现的时候,我们还需要两个辅助的数据结构:

1、邻接表:通过结点的索引,我们能够得到这个结点的后继结点;

2、入度数组:通过结点的索引,我们能够得到指向这个结点的结点个数。

3.入度为0的队列

具体做如下:

1、在开始排序前,扫描对应的存储空间(使用邻接表),将入度为 0 的结点放入队列。

2、只要队列非空,就从队首取出入度为 0 的结点,将这个结点输出到结果集中,并且将这个结点的所有邻接结点(它指向的结点)的入度减 1,在减 1 以后,如果这个被减 1的结点的入度为 0 ,就继续入队。

一、节点、图定义 

public class Node {
	public Object val;
	public int pathIn = 0; // 入链路数量
	public Node(Object val) {
		this.val = val;
	}

}

public class Graph {

	// 图中节点的集合
			public Set<Node> vertexSet = new HashSet<Node>();
			// 相邻的节点,纪录边
			public Map<Node, Set<Node>> adjaNode = new HashMap<Node, Set<Node>>();
	 
			// 将节点加入图中
			public boolean addNode(Node start, Node end) {
				if (!v
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值