算法系列3之拓扑排序

一.拓扑排序

1.基础概念

AOV网

拓扑排序:根据步骤算法入度,出度要实时更新,所以正邻接表只记录了出度,十字链表反而麻烦,于是应用下方模型

辅助数组(入度)+邻接表模型

应用 : 应用与项目管理软件(AOV网)

2.核心思路

3.步骤

先遍历,更新入度统计表

  1. 找到图中,入度为0的顶点,把这些顶点放入缓存中(栈、队列)

  2. 从缓存区中,取出一个顶点,放入到结果集

  3. 这个顶点的事件发生了,顶点的对应出度消失,有其他顶点的入度随之消失。

  4. 又会增加新的入度为0的顶点出现,如果出现,放入缓存

  5. 重复2-3-4

  6. 取出缓存中的所有顶点数量:a1,图中顶点的总个数为a2;

a1 == a2 没有环,a1 < a2 有环

二.代码

.h

.c

main.c

相关推荐
!停2 小时前
数据结构排序算法—插入排序
数据结构·算法·排序算法
s砚山s2 小时前
代码随想录刷题——二叉树篇(二十一)
算法
adore.9682 小时前
2.21 oj基础89 90 91+U12B部分
开发语言·c++
feng_you_ying_li2 小时前
data类的实现
c++
谁不学习揍谁!2 小时前
基于python大数据机器学习旅游数据分析可视化推荐系统(完整系统+开发文档+部署教程+文档等资料)
大数据·python·算法·机器学习·数据分析·旅游·数据可视化
yyjtx2 小时前
DHU上机打卡D28
开发语言·c++·算法
楼田莉子2 小时前
CMake学习:CMake在二进制工程场景上应用
linux·c++·vscode·学习·软件构建
programhelp_2 小时前
Snowflake OA 2026真题解析|3道Hard Coding全拆解,附DP+双指针实战思路
算法
2501_918126912 小时前
stm32程序是用什么语言写的?
c语言·stm32·单片机·嵌入式硬件·个人开发