#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
题目大意:给定一个无向图,要求删除一些边使点p和点q不连通,首先是使花费最少,若有多组解则使删除的边最少。
分析:典型的最小割,最大流即可。只需要把每边的花费c改为c = c * (|E| + 1) + 1即可使删除的边最少,其中|E|为边数。为方便把|E|换为一个较大的数也可以。
#include
#include
#include
#include
#include
#include
分析:搞笑题,就不解释了。
题目大意:给定一个有向图,要求把点分为k个集合,使得每个集合中的任意两点a, b满足a, b互相不可到达。
分析:求出强连通分量后缩点,得到有向无环图,dfs该图求出各点深度(深度加权,权值为强连通分量大小),深度最大值即答案,因为这一条路径上任意两点都可从深度小的一点到达深度大的一点,所以必定属于不同集合;又可以把其它路径(长度为len)上的各点依次归到集合1..len。
#include
#include
#include
#include
#include
#include