拓扑排序代码模板

一些注意的点都在代码注释中了。

cpp 复制代码
//有向图无环图中才有拓扑排序,且都是前面的编号的点指向后面编号的点
#include<iostream>
#include<cstring>
using namespace std;
const int N = 1e5 + 9;
int e[N], ne[N], h[N], idx, n, m, d[N], q[N];

void add(int a, int b)
{
	e[idx] = b, ne[idx] = h[a], h[a] = idx++;
}

bool topsort()
{
	int hh = 0, tt = -1;
	//将所有入度为0的点入队,编号从1~n
	for (int i = 1; i <= n; ++i) if (!d[i]) q[++tt] = i;

	while (hh <= tt)
	{
		int t = q[hh++];//出队
		for (int i = h[t]; i != -1; i = ne[i])
		{
			int j = e[i];
			d[j]--;//因为t指向j,又因为t删除了,所以j入度减一
			if (!d[j]) q[++tt] = j;
		}
	}
	return tt == (n - 1);//如果每个点都入队了表明为拓扑排序
}

int main()
{
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	memset(h, -1, sizeof h);
	cin >> n >> m;
	for (int i = 0; i < m; ++i)
	{
		int a, b; cin >> a >> b;
		add(a, b);
		d[b]++;//入度加一
	}
	//队列中的顺序刚好就是拓扑排序,排序不唯一
	if (topsort()) for (int i = 0; i < n; ++i) cout << q[i] << " ";
	else cout << -1;
	return 0;
}
相关推荐
成都易yisdong几秒前
C# 实现道路横断面自动生成与格式转换(最小二乘拟合 + 方向向量法)
windows·算法·c#·visual studio
无限进步_1 分钟前
二叉树的前序遍历(非递归实现)
开发语言·数据结构·c++·windows·git·visual studio
ximu_polaris4 分钟前
设计模式(C++)-结构型模式-组合模式
c++·设计模式·组合模式
青瓦梦滋5 分钟前
Linux线程的同步与互斥
linux·c++
01二进制代码漫游日记6 分钟前
【C语言数据结构】之解锁双向链表(头插、头删等操作)
c语言·数据结构·学习·链表
南境十里·墨染春水6 分钟前
C++流类库 文件流操作
开发语言·c++
C++ 老炮儿的技术栈8 分钟前
工业视觉检测:用 C++ 和 Snap7 库快速读写西门子 S7-1200
c语言·c++·git·qt·系统架构·visual studio·snap
阿Y加油吧10 分钟前
算法二刷复盘:LeetCode 39 组合总和 & 22 括号生成(Java 回溯精讲)
java·算法·leetcode
橙子也要努力变强11 分钟前
信号捕捉的底层机制-内核态和用户态初识
linux·服务器·c++
WL_Aurora15 分钟前
每日一题——自然倍树
数据结构·python·算法·深度优先