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

拓扑排序是一种无环的有向图的排序,了解拓扑排序之前,我们先了解一下什么是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;
}
相关推荐
CoovallyAIHub12 分钟前
一夜之间,大模型处理长文本的难题被DeepSeek新模型彻底颠覆!
深度学习·算法·计算机视觉
天选之女wow18 分钟前
【代码随想录算法训练营——Day43(Day42周日休息)】动态规划——300.最长递增子序列、674.最长连续递增序列、718.最长重复子数组
算法·leetcode·动态规划
敲代码的嘎仔1 小时前
JavaWeb零基础学习Day4——Maven
java·开发语言·学习·算法·maven·javaweb·学习方法
聪明的笨猪猪1 小时前
hot 100 (1)—— 两数之和(哈希)
java·经验分享·算法·哈希算法
_dindong2 小时前
牛客101:链表
数据结构·c++·笔记·学习·算法·链表
wuk9982 小时前
基于位置式PID算法调节PWM占空比实现电机转速控制
单片机·嵌入式硬件·算法
不到满级不改名2 小时前
EM算法 & 隐马尔可夫模型
算法
workflower6 小时前
单元测试-例子
java·开发语言·算法·django·个人开发·结对编程
MicroTech20258 小时前
微算法科技(MLGO)研发突破性低复杂度CFG算法,成功缓解边缘分裂学习中的掉队者问题
科技·学习·算法
墨染点香9 小时前
LeetCode 刷题【126. 单词接龙 II】
算法·leetcode·职场和发展