图论拓扑排序

拓扑排序(有向无环图):事件之间存在依赖关系,事件A依赖于事件B,那么A的实现的前提是B先实现

对于图论来说,图谱排序就是将一个有向图转换成线性的排序,其中很重要的一点是判断图中有无环,即存在循环依赖的话就不能做线性排序。

BFS和DFS都可以,掌握BFS(卡恩算法)

步骤:

  1. 优先找到入度为0的节点,它是起点,加入结果集
  2. 将该节点从图中移除

拓扑排序就是重复以上过程,如果找不到入度为0的节点说明有环,拓扑算法也是判断有向环的方法。

第一次写,忘记在广搜的过程中判断当前文件是否有后续文件了

可以用邻接表存有向图,别忘记初始化表的大小,使用邻接表的好处

遍历更高效:没有引入哈希结构,更适合图

更小的内存开销:map需要维持平衡树的结构,unordered_map也要维持哈希桶,相比下vector开销更小

避免隐式初始化:如果u不存在,map会自动创建一个u,可能引起bug

相关推荐
AICodeThunder1 天前
【S组篇】C++知识点总结(1):并查集基础
c语言·数据结构·c++·算法·图论
极客数模3 天前
2025年MathorCup 大数据竞赛明日开赛,注意事项!论文提交规范、模板、承诺书正确使用!2025年第六届MathorCup数学应用挑战赛——大数据竞赛
大数据·python·算法·matlab·图论·比赛推荐
大数据张老师3 天前
【无标题】
算法·图论
许小禾上学记3 天前
学习笔记 | 图论基础
笔记·学习·图论
小李小李快乐不已3 天前
图论理论基础(1)
数据结构·算法·leetcode·深度优先·图论·广度优先·宽度优先
大数据张老师4 天前
数据结构——广度优先搜索
数据结构·图论·宽度优先
YSRM5 天前
Leetcode+Java+图论+最小生成树&拓扑排序
java·leetcode·图论
YSRM5 天前
Leetcode+Java+图论+并查集
算法·leetcode·图论
YSRM5 天前
Leetcode+Java+图论II
java·leetcode·图论
晚枫~6 天前
图论基础:探索节点与关系的复杂网络
网络·数据结构·图论