C++图论基础拓扑排序算法流食般投喂

声明:以下知识相关资料来自比特官网和小编手搓~


有向无环图的概念:

顾名思义,首先就是一个有向图,其次就是这个有向图里面不存在回路(环)。


AOV网的概念:

就类似于一门系统课,他课程的设计肯定是合理的,有简单到难,知识深度层层递进的,每一门课程都有优先级,学完他,在学她。

在这种有向图中,用顶点表示活动,用有向边<Vi, Vj>表示活动Vi必须先于活动Vj举办,这种有向图叫做顶点表示活动的网络,简称AOV网(Activity On Vertex Network)。

AOV网中不能有回路,不然就不能确定哪一个活动先举行了。因此,AOV网必须是一个有向无环图。


拓扑排序的代码原理&作用:

拓扑排序的实现是借助于对列用bfs实现的,同时对于每个顶点都会记录此时有多少指向他的边,即记录该顶点的入度 inN

此时提供一波小连招:

1、先把入度为0的顶点扔进对列

2、拿出队首元素,删除连带的边--->让被指的顶点的入度减1,就是代表这边对于这一个被指的顶点删除了。

3、此时会产生新的入度为0的顶点,把他们扔进对列

4、重复2、3,直至图中没有顶点或没有入度为0的顶点了


拓扑排序可以判断图中有没有环:

跑一遍拓扑排序算法,如果有顶点没有进队列,那么就代表有环。(环的入度不可能为0,进不来队列)


OJ题来源:洛谷

OJ题名:【模板】拓扑排序/家谱树

OJ题归属:图论基础【拓扑排序】

解题算法:拓扑排序

cpp 复制代码
#include<iostream>
#include<vector>
#include<queue>

using namespace std;

const int N = 110;

int n;
vector<int> a[N]; // 存图 -- 孩子表示法
int in[N]; // 存入度

int main()
{
	cin >> n;
	for (int i = 1; i <= n; i++)
	{
		int x;
		while (cin >> x, x)
		{
			a[i].push_back(x);
			// 是 i 的孩子,肯定会被他的边指,入度加一
			in[x]++;
		}
	}

	queue<int> q;
	// 找出入度为0的入队
	for (int i = 1; i <= n; i++)
	{
		if (in[i] == 0) q.push(i);
	}

	while (q.size())
	{
		int p = q.front(); q.pop();
		cout << p << " ";

		// 遍历p的孩子
		for (auto& e : a[p])
		{
			// 删边
			in[e]--;
			// 把此时入度为0的顶点入队
			if (in[e] == 0) q.push(e);
		}
	}

	return 0;
}
相关推荐
郝学胜-神的一滴1 小时前
Qt 高级开发 030:QListWidget 右键菜单全解,从策略配置到精准删除的优雅实现
开发语言·c++·qt·程序人生·用户界面
knighthood20011 小时前
ros2-quick-runner插件v0.0.4版本发布
android·java·开发语言
All_Will_Be_Fine噻1 小时前
重建R环境
开发语言·r语言
磊 子1 小时前
二.内核讲解
开发语言·操作系统·系统
zyl837211 小时前
Java 后端完整技术栈
java·开发语言
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第107题】【并发篇】第7题:说说 Lock 锁?
java·开发语言·面试
海棠AI实验室2 小时前
AI 时代文献综述:从检索到成稿的 RAG 五步法
windows·算法·自动化·llm·rag
H178535090962 小时前
SolidWorks_基于草图的实体特征14_扫描扭转与控制
前端·人工智能·算法·3d建模·solidworks
黄金龙PLUS2 小时前
基于ARX结构的新型序列密码算法FlashLight
算法·网络安全·密码学·哈希算法·同态加密