图论拓扑排序

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

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

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

步骤:

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

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

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

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

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

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

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

相关推荐
xvhao20132 天前
单源、多源最短路
数据结构·c++·算法·深度优先·动态规划·图论·图搜索算法
txzrxz3 天前
关于前缀和
算法·动态规划·图论
handler014 天前
算法:图的基本概念
c语言·开发语言·c++·笔记·算法·图论
WolfGang0073215 天前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
星马梦缘5 天前
算法设计与分析 作业二 答案与解析
算法·图论·dfs·bfs·floyd-warshall·bellman_ford·多源最短路
故事和你915 天前
洛谷-算法2-4-字符串2
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
故事和你916 天前
洛谷-算法2-3-分治与倍增5
开发语言·数据结构·c++·算法·动态规划·图论
WolfGang0073216 天前
代码随想录算法训练营 Day49 | 图论 part07
算法·图论
WolfGang0073217 天前
代码随想录算法训练营 Day48 | 图论 part06
算法·图论
WolfGang0073218 天前
代码随想录算法训练营 Day47 | 图论 part05
算法·图论