拓扑排序 堆
妙蛙
注意到这是一个DAG,那么我们可以一遍拓排求出从起点到 i i i为最长路 d s [ i ] ds[i] ds[i]和 i i i到终点的最长路 d t [ i ] dt[i] dt[i](s向所有入度为0的点连边,所有出度为0的点向t连边)。若一条最长路 l l l经过 ( u , v ) (u,v) (u,v),那么必有 l = d s [ u ] + d t [ v ] + 1 l=ds[u]+dt[v]+1 l=ds[u]+dt[v]+1。
我们按照拓扑序枚举每个点。每次把关于它的最长路从 t t t集删掉并更新答案,然后把它们加到 s s s集里。因此要维护的就是三个操作:删除一个数,插入一个数和查询最大值。用堆即可。
代码:
#include<queue>
#include