【SCOI2007】修车 【题目描述】 同一时刻有N位车主带着他们的爱车来到了汽车维修中心。维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的。现在需要安排这M位技术人员所维修的车及顺序,使得顾客平均等待的时间最小。 说明:顾客的等待时间是指从他把车送至维修中心到维修完毕所用的时间。 【输入】 第一行有两个m,n,表示技术人员数与顾客数。 接下来n行,每行m个整数。第i+1行第j个数表示第j位技术人员维修第i辆车需要用的时间T。 【输出】 最小平均等待时间,答案精确到小数点后2位。 【输入样例】 2 2 3 2 1 4 【输出样例】 1.50 【数据范围】 2<=M<=9,1<=N<=60, 1<=T<=1000 【题解】 这道题是费用流的一个简单构图应用,所以解法当然是费用流咯。 首先要理清题意,平均等待时间这一点类似于经典题目排队接水,但不能满足每一步的安排无后效性。那么就来一个整体的安排,对于每个修理工人,修理数目从1到n不等,那么就把每个工人拆为n个点,其中(i,j)表示第i个工人修理的第j辆车。 若第i个工人修理第j辆车的时间为t[i,j],那么创造的等待时间就为j*t[i,j],这一点和排队接水相同。每个顾客和拆点后的工人相连,费用即为创作的等待时间,流量均为1。 接下来虚拟一个源点、一个汇点,源点和所有顾客相连,汇点和拆点后的工人相连,费用都为0,流量都为1,最小费用最大流,okay~ 【代码】 注意SPFA必须使用SLF优化,因为反向弧的费用是负数。 【SCOI2007】修车#代码