「POJ2175」Evacuation Plan

题目

点这里看题目。

分析

显而易见的方法:直接建图跑一个最小费用最大流,然后比较自己得到的结果和给出的方案。

但是这里有 \(O(n^2)\) 条边,再加上流量可以被构造得很大,因此这种方法不出所料地超时了。

注意到,题目给出的方案一定是一个最大流的方案,但不一定是最小费用的方案。换句话说,题目其实给出了一个残量网络。根据完全不众所周知的消圈原理,如果这个残量网络上存在负环,那么这个流就一定不是最小费用流。另外,如果搜索到了一个负环,我们也可以在这个负环上调整 1 的流量,从而得到一种更优的方案,因此也可以很容易地构造出方案。

理论的复杂度应为 \(O(n^2m)\),勉强能够过去。如果使用 DFS 版本的 SPFA 并加上若干优化,那么就能跑得飞快

上一篇:JDBC入门之一--连接Mysql实验


下一篇:[Python] Importing Python Modules