sgu 176 Flow construction
链接:http://acm.sgu.ru/problem.php?contest=0&problem=176
题意:有一个加工厂,里面有n台机器,起点为1终点为n。中间的生产环节有货物限制,输入m个环节。每个环节有u,v,z,c四个数字。u表示起始机器,v表示终止机器,如果c为1,那么这条边的流量必须为z。如果c为0,那么流量在[0, z]之间。保证没有自环,没有重边,只有1号机器能够生产货物,n号机器消耗货物,其他机器不能积累货物。问满足条件的情况下,1号机器最少要生产多少货物。
思路: 有源汇有上下界的最小流 1. 增设一个超级源点,一个超级汇点,以同样的方式将原网络转化为没有流量下界限制的新网络。 2. 不连接原先网络的源汇点,并以超级源汇点为起点,终点做一次最大流maxflow1。 3. 此时从汇点向源点连接一条流量为INF的边,再以超级源汇点做一次网络流maxflow2。 4. 如果从源点出发的流均为满流,则有最小流,最小流的值为从汇点流向源点的流量。 * 在判断是否为满流时,条件为 maxflow1 + maxflow2 = 超级源点流出的流量 * 可以理解为第一遍做网络流时并无T->S的边,所以S->T的流量在第一遍时都已尽力往其他边流了. 于是加上T->S这条边后,都是些剩余的流不到其他边的流量. 从而达到尽可能减少T->S这边上的流量的效果,即减小了最终答案.
代码:
/*
ID: wuqi9395@126.com
PROG:
LANG: C++
*/
#include