上次我们学习了prim和kruskal算法还有LCA点的知识,全是干货……详见《图论9 prim+LCA算法详解》。
今天我们来学一个简单又易学的排序算法——拓扑排序。
在接触之前,我们先来学一种图,他的名字叫有向无环图(DAG)。这种图指的是一个不包括环的有向图,但是不能是一棵树,要不可能就成了这个图的生成树,这个生成树叫有向树。
接下来我们在学习几个干货:点的前驱和后继。一个点的前驱是在到这个点以前必须先到的点,一个点的后继是经过这个点以后可以到达的点。但是注意,这些的前提是没有回路,否则就代表一个活动以自己为先决条件,这些活动会循环下去,这不科学!
接下来我们在学一个STL库里的数据结构:priority_queue(循环队列),这个东西的定义很长,是这样的:
priority_queue<int,vector<int>,greater<int> >q;
比一般的语句要长两倍,但在拓扑排序里可以用它判断回路,因为拓扑排序基于DAG图,不能有环,要不这个图就排不出来了。
拓扑排序其实代码很简单,用dfs或者bfs都能