蓝桥杯备考:图论之拓扑排序

拓扑排序是一种无环的有向图的排序,了解拓扑排序之前,我们先了解一下什么是AOV图

AOV网不能有回路,不然就不能确定先后次序了

拓扑排序的目标就是把有向无环图中的所有结点排序,使得排在前面的结点不会依赖后面的结点

流程如下:step1:找到所有入度为0的点,加入到队列中

step2:依次删除队列里的队头结点,每次删除的时候把连着该结点的边也删掉,并且把新的入度为0的点加入进来

step3:直到队列中没有结点了,此时排序结束

如果队列里有环,是不能把所有结点都排上序的,所以拓扑排序还可以判断图里有没有环

具体流程

好的,我们来做一下模板题

cpp 复制代码
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
const int N = 110;
int in[N];
int n;
vector<int> edges[N];
int main()
{
	cin >> n;
	for(int i = 1;i<=n;i++)
	{
		int x;
		while(cin>>x,x)
		{
			edges[i].push_back(x);
			in[x]++;
		}
	}
	queue<int> q;
	for(int i = 1;i<=n;i++)
	{
		if(in[i]==0) q.push(i);
	}
	while(q.size())
	{
		auto t = q.front();q.pop();
		cout << t << " ";
		for(auto &e : edges[t])
		{
			in[e]--;
			if(in[e]==0)
			{
				q.push(e);
			}
		}
	}
	
	
	
	return 0;
}
相关推荐
2301_822703202 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
cmpxr_2 小时前
【C】数组名、函数名的特殊
c语言·算法
KAU的云实验台3 小时前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆3 小时前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
大熊背4 小时前
如何利用Lv值实现三级降帧
算法·自动曝光·lv·isppipeline
大尚来也4 小时前
驾驭并发:.NET多线程编程的挑战与破局之道
java·前端·算法
向阳而生,一路生花4 小时前
深入浅出 JDK7 HashMap 源码分析
算法·哈希算法
君义_noip4 小时前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
摸个小yu4 小时前
【力扣LeetCode热题h100】链表、二叉树
算法·leetcode·链表
汀、人工智能5 小时前
[特殊字符] 第93课:太平洋大西洋水流问题
数据结构·算法·数据库架构·图论·bfs·太平洋大西洋水流问题