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

相关推荐
csdn_aspnet1 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士1 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
C+++Python3 小时前
C++ 进阶学习完整指南
java·c++·学习
sparEE3 小时前
c++值类别、右值引用和移动语义
开发语言·c++
jrrz08284 小时前
Apollo MPC Controller
c++·自动驾驶·apollo·mpc·横向控制·lateral control
gaosushexiangji4 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言6 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
学习,学习,在学习6 小时前
Qt工控仪器程序框架设计详解(工控多仪器控制版本)
开发语言·c++·qt
kyle~6 小时前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
三品吉他手会点灯6 小时前
C语言学习笔记 - 35.数据类型 - printf函数的非输出控制符与格式优化
c语言·开发语言·笔记·学习