【
题意】每台计算机由P个零件组成,工厂里有n台机器,每台机器针对P个零件有不同的输入输出规格,现在给出每台机器每小时的产量,问如何建立流水线(连接各机器)使得每小时生产的计算机最多。
网络流的建图真的比较有意思~~
【
建图】如下图,建一个输出规格都为0的超级源点表示起始状态,建一个输入规格都为1的超级汇点表示完成一台电脑,把每一个机器拆成一个源点和一个汇点,之间连一条performance的边表示每小时能产几台。对于任意两台机器,如果其中一台的输出规格=另一台的输入规格,则两边连一条无穷流量的边(包括超级源汇点),求出最大流即可。
【
输出解】这个比较好想,遍历流网络,可以只看反向边,如果反向边流量>0则表示该条边有流量,输出.
#include
#include
#include
#include
#include
#include
#include
#include