博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 3686 The Windy's(思维+费用流好题)
阅读量:5460 次
发布时间:2019-06-15

本文共 4081 字,大约阅读时间需要 13 分钟。

The Windy's
Time Limit: 5000MS   Memory Limit: 65536K
Total Submissions: 5362   Accepted: 2249

Description

The Windy's is a world famous toy factory that owns M top-class workshop to make toys. This year the manager receives N orders for toys. The manager knows that every order will take different amount of hours in different workshops. More precisely, the i-th order will take Zij hours if the toys are making in the j-th workshop. Moreover, each order's work must be wholly completed in the same workshop. And a workshop can not switch to another order until it has finished the previous one. The switch does not cost any time.

The manager wants to minimize the average of the finishing time of the N orders. Can you help him?

Input

The first line of input is the number of test case. The first line of each test case contains two integers, N and M (1 ≤ N,M ≤ 50).

The next N lines each contain M integers, describing the matrix Zij (1 ≤ Zij ≤ 100,000) There is a blank line before each test case.

Output

For each test case output the answer on a single line. The result should be rounded to six decimal places.

Sample Input

33 4100 100 100 199 99 99 198 98 98 13 41 100 100 10099 1 99 9998 98 1 983 41 100 100 1001 99 99 9998 1 98 98

Sample Output

2.0000001.0000001.333333

题目连接:

刷白书的网络流问题看到的,跟某一道导弹发射的问题很像,但是这题不同工厂对不同的物品都有不同的加工时间,按加工次序拆点是很容易想到, 但这样一想有一个问题,比如我把物品连到工场2的第二次加工时间点,那我这条边流量是1,费用是多少根本不知道,因为我不知道工厂2第一次加工的那条边费用是多少,即不知道当前物品加工时等待了多久,因此需要换一种思路。

比如有三个物品a,b,c都在同一个工厂加工,那么时间可以这么写:ta+ta+tb+ta+tb+tc=3ta+2tb+1tc,显然最先加工的是a,其次是b,最后是c,可以发现物品前面的系数的最大值就是在工厂加工的总物品数,那么这题实际上就是一个系数分配问题,那么建图就好办了, 费用就是加工次序*加工时间,由于流量是1,确实解决了同一时间只能加工一个物品的问题,但可能又会想,那我的某一个物品万一在工厂1的第k次序加工,但是实际上工厂1前k-1次机会都没有用过,这岂不是非常浪费吗?实际上由于用的是SPFA最短路增广,求解过程就是求出了总时间最优的情况,不会出现前面空着的加工次序问题,如果有空着的加工次序,那么SPFA一定会找到并把这条边松弛算进网络流中

代码:

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define INF 0x3f3f3f3f#define LC(x) (x<<1)#define RC(x) ((x<<1)+1)#define MID(x,y) ((x+y)>>1)#define CLR(arr,val) memset(arr,val,sizeof(arr))#define FAST_IO ios::sync_with_stdio(false);cin.tie(0);typedef pair
pii;typedef long long LL;const double PI = acos(-1.0);const int N = 55;const int MAXV = N + N * N;const int MAXE = N + N * N + N * N * N;struct edge{ int to, nxt, cap, cost; edge() {} edge(int _to, int _nxt, int _cap, int _cost): to(_to), nxt(_nxt), cap(_cap), cost(_cost) {}};edge E[MAXE << 1];int head[MAXV], tot;int vis[MAXV], pre[MAXV], path[MAXV], d[MAXV];int Z[N][N];int mc, mf;void init(){ CLR(head, -1); tot = 0; mc = mf = 0;}inline void add(int s, int t, int cap, int cost){ E[tot] = edge(t, head[s], cap, cost); head[s] = tot++; E[tot] = edge(s, head[t], 0, -cost); head[t] = tot++;}int spfa(int s, int t){ queue
Q; Q.push(s); CLR(d, INF); CLR(vis, 0); d[s] = 0; vis[s] = 1; while (!Q.empty()) { int u = Q.front(); Q.pop(); vis[u] = 0; for (int i = head[u]; ~i; i = E[i].nxt) { int v = E[i].to; if (d[v] > d[u] + E[i].cost && E[i].cap > 0) { d[v] = d[u] + E[i].cost; pre[v] = u; path[v] = i; if (!vis[v]) { vis[v] = 1; Q.push(v); } } } } return d[t] != INF;}void MCMF(int s, int t){ int i; while (spfa(s, t)) { int Min = INF; for (i = t; i != s; i = pre[i]) Min = min(Min, E[path[i]].cap); for (i = t; i != s; i = pre[i]) { E[path[i]].cap -= Min; E[path[i] ^ 1].cap += Min; } mf += Min; mc += Min * d[t]; }}int main(void){ int tcase, n, m, i, j, k; scanf("%d", &tcase); while (tcase--) { init(); scanf("%d%d", &n, &m); for (i = 1; i <= n; ++i) for (j = 1; j <= m; ++j) scanf("%d", &Z[i][j]); int S = 0, T = n + n * m + 1; for (i = 1; i <= n; ++i) //n源点到需加工物品 add(S, i, 1, 0); for (i = n + 1; i <= n + n * m; ++i) //n*m加工时间点到汇点 add(i, T, 1, 0); for (i = 1; i <= n; ++i) { for (j = 1; j <= m; ++j) { for (k = 1; k <= n; ++k)//遍历不同时间点 { int id = j * n + k; add(i, id, 1, k * Z[i][j]); //n*m*n } } } MCMF(S, T); printf("%.6f\n", mc * 1.0 / n); } return 0;}

转载于:https://www.cnblogs.com/Blackops/p/7103040.html

你可能感兴趣的文章
idea创建Maven工程很慢的解决办法
查看>>
工作流引擎activiti入门
查看>>
cowboy rest
查看>>
setChecked方法触发onCheckedChanged监听器问题
查看>>
vim php代码规范
查看>>
numpy次方计算
查看>>
centos7 搭建LNMP
查看>>
Python OOP(1)
查看>>
delphi 数据库中Connection与Query连接数量问题思考
查看>>
JS图像变换效果的实现
查看>>
sql function递归
查看>>
【Alpha】Daily Scrum Meeting——blog2
查看>>
struts2 局部类型转换器
查看>>
all与any的用法
查看>>
SpringBoot入门教程(六)SpringBoot2.0统一处理404,500等http错误跳转页
查看>>
mysql 去除重复 Select中DISTINCT关键字的用法
查看>>
JSON
查看>>
poj1006
查看>>
win7下搭建WAMP图解(PHP运行环境:win7+Apache2.2+php5.2.8+MySQL5.5)附安装包
查看>>
二、什么是IBeamMDAA
查看>>