算法系列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

相关推荐
无忧.芙桃17 小时前
C++11的部分内容(上)
c++
罗超驿17 小时前
Java数据结构_链表
java·数据结构·链表
小璐资源网17 小时前
C++中如何正确区分`=`和`==`的使用场景?
java·c++·算法
卢锡荣17 小时前
LDR6021Q 车规级 Type‑C PD 控制芯片:一芯赋能,边充边传,稳驭全场景
c语言·开发语言·ios·计算机外设·电脑
N1_WEB17 小时前
HDU:杭电 2018 复试真题汇总
算法
AMoon丶18 小时前
C++模版-函数模版,类模版基础
java·linux·c语言·开发语言·jvm·c++·算法
We་ct18 小时前
LeetCode 79. 单词搜索:DFS回溯解法详解
前端·算法·leetcode·typescript·深度优先·个人开发·回溯
眼眸流转18 小时前
LeetCode热题100(四)
算法·leetcode·职场和发展
相信神话202118 小时前
第零章:新手的第一课:正确认知游戏开发
大数据·数据库·算法·2d游戏编程·godot4·2d游戏开发
汀沿河19 小时前
2 模型预训练、微调、强化学习的格式
人工智能·算法·机器学习