Description

同一时刻有\(N\)位车主带着他们的爱车来到了汽车维修中心。维修中心共有\(M\)位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的。现在需要安排这\(M\)位技术人员所维修的车及顺序,使得顾客平均等待的时间最小。 说明:顾客的等待时间是指从他把车送至维修中心到维修完毕所用的时间。

Input

第一行有两个\(m,n\),表示技术人员数与顾客数。 接下来\(n\)行,每行\(m\)个整数。第\(i+1\)行第\(j\)个数表示第\(j\)位技术人员维修第\(i\)辆车需要用的时间\(T_{j,i}\)。

Output

最小平均等待时间,答案精确到小数点后\(2\)位。

Sample Input

2 2

3 2

1 4

Sample Output

1.50

HINT

\((2 \le M \le 9,1 \le N \le 60), (1 \le T \le 1000)\)

这是一道比较明显的费用流题目。

这题构图很巧妙:

将每个工人拆成\(n\)个点,设第\(i\)个工人拆成的第\(j\)个点为\(P_{i,j}\),\(P_{i,j}\)表示第\(i\)个人倒数第\(j\)个修的车是哪一辆。

\(P_{i,j}\)向第\(k\)辆车连接一条容量为\(1\),费用为\(T_{i,k} \times j\)的边。

接着就是连接源汇点,最后跑最大费用最大流即可。

正确性也很明显。每个工人修的车只可以对它后面修的产生代价,而代价正好就是它的倒数名次与其时间的乘积。

zkw费用流是蒯的hzwer的,应该可以敲spfa吧。

#include<cstdio>
#include<cstdlib>
#include<queue>
#include<cstring>
using namespace std;
#define inf 0x7fffffff
#define T 601
using namespace std;
int n,m,cnt = 1,ans,t[61][10];
int d[605],q[605],from[605],head[605];
bool mark[605];
struct edge{int from,to,next,c,v;}e[100001]; inline int small(int a,int b) {if (a < b) return a; return b;} void ins(int u,int v,int w,int c)
{
cnt++;
e[cnt].from = u; e[cnt].to = v;
e[cnt].next = head[u]; head[u] = cnt;
e[cnt].c = c; e[cnt].v = w;
} void insert(int u,int v,int w,int c)
{
ins(u,v,w,c); ins(v,u,0,-c);
} bool spfa()
{
memset(mark,0,sizeof(mark));
memset(d,0x7,sizeof(d));
d[T] = 0; mark[T] = 1;
queue <int> team;
team.push(T);
while (!team.empty())
{
int now = team.front();
team.pop();
for (int i = head[now];i;i = e[i].next)
if (e[i^1].v&&d[e[i].to] > d[now]-e[i].c)
{
d[e[i].to] = d[now]-e[i].c;
if (!mark[e[i].to])
{
mark[e[i].to] = true;
team.push(e[i].to);
}
}
mark[now] = false;
}
if (d[0] > 10000000) return false;
return true;
} int dfs(int x,int f)
{
if (x == T)
{
mark[T] = 1;
return f;
}
int used = 0,w;
mark[x] = true;
for (int i = head[x];i;i = e[i].next)
if (!mark[e[i].to]&&e[i].v&&d[x]-e[i].c==d[e[i].to])
{
w = f - used;
w = dfs(e[i].to,small(e[i].v,w));
ans += w*e[i].c;
e[i].v -= w;
e[i^1].v += w;
used += w;
if (used == f) return f;
}
return used;
} void zkw()
{
while (spfa())
{
mark[T] = 1;
while (mark[T])
{
memset(mark,0,sizeof(mark));
dfs(0,inf);
}
}
} int main()
{
freopen("1070.in","r",stdin);
freopen("1070.out","w",stdout);
int i,j,k;
scanf("%d %d",&n,&m);
for (i = 1;i<=m;i++)
for (j = 1;j<=n;j++)
scanf("%d",t[i]+j);
for (i = 1;i<=n*m;i++)
insert(0,i,1,0);
for (int i = n*m+1;i<=n*m+m;i++)
insert(i,T,1,0);
for (i = 1;i<=n;i++)
for (j = 1;j<=m;j++)
for (k = 1;k<=m;k++)
insert((i-1)*m+j,n*m+k,1,t[k][i]*j);
zkw();
printf("%.2lf",(double)ans/m);
return 0;
}

BZOJ 1070 修车的更多相关文章

  1. BZOJ 1070 修车(最小费用流)

    链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1070 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术 ...

  2. bzoj 1070 修车 —— 费用流

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1070 需要考虑前面修的车对后面等待的车造成的时间增加: 其实可以从每个人修车的顺序考虑,如果 ...

  3. BZOJ 1070 修车 【费用流】

    Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同 的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序, ...

  4. BZOJ 1070 修车(费用流)

    如果能想到费用流,这道题就是显然了. 要求所有人的等待平均时间最小,也就是所有人的总等待时间最小. 每辆车只需要修一次,所以s连每辆车容量为1,费用为0的边. 现在需要把每个人拆成n个点,把车和每个人 ...

  5. [BZOJ 1070] [SCOI2007] 修车 【费用流】

    题目链接:BZOJ - 1070 题目分析 首先想到拆点,把每个技术人员拆成 n 个点,从某个技术人员拆出的第 i 个点,向某辆车连边,表示这是这个技术人员修的倒数第 i 辆车.那么这一次修车对整个答 ...

  6. BZOJ 1070: [SCOI2007]修车 [最小费用最大流]

    1070: [SCOI2007]修车 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 4936  Solved: 2032[Submit][Status] ...

  7. bzoj 1070: [SCOI2007]修车 费用流

    1070: [SCOI2007]修车 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 2785  Solved: 1110[Submit][Status] ...

  8. bzoj 1070 [SCOI2007]修车(最小费用最大流)

    1070: [SCOI2007]修车 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 3515  Solved: 1411[Submit][Status] ...

  9. 【BZOJ 1070】[SCOI2007]修车

    Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序,使 ...

随机推荐

  1. 在ASP.NET中,IE与Firefox下载文件带汉字名时乱码的解决方法

    解决办法: HttpContext.Current.Response.Clear(); HttpContext.Current.Response.Buffer = true; HttpContext. ...

  2. Android开发ImageView控件缩放图片

    首先还是最基础的ImageView控件如何显示图片: <ImageView                Android:id="@+id/imgView"          ...

  3. 设计模式22---设计模式之解释器模式(Interpreter)(行为型)

    1.讲解解释器模式 1.1解释器模式定义 给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子. 1.2解释器模式要点 解析器:把描述客户端调用要求的表达式, ...

  4. spring mvc DispatcherServlet详解之一---处理请求深入解析(续)

    上文中,我们知道分发过程有以下步骤: 分发过程如下: 1. 判断是否设置了multipart resolver,设置的话转换为multipart request,没有的话则继续下面的步骤. 2. 根据 ...

  5. [转]Flex 布局教程:语法篇

    网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  6. HTML简单介绍及常见元素

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  7. WebForm开发常用代码

    1.获取服务器绝对路径: public static string GetMapPath(string strPath) { if (HttpContext.Current != null) { re ...

  8. 使用ListView 时,遇到了 Your content must have a ListView whose id attribute is 'android.R.id.list' 错误

    今天在开发Android小应用的时候,使用到了ListView,在使用自己创建的listview风格的时候,就出现了如标题的错误提示信息,这个就让我纳闷了,以前也不会出现这个问题啊,而且也可以运行,赶 ...

  9. Java实现ajax

    jsp端的代码,sucess:function(){} 里面就是返回的处理 function ChangeTime(){ alert("www"); var startYmd = ...

  10. jQuery实现页面滚动时顶部动态显示隐藏

    http://www.jqcool.net/jquery-scroll.html 另外headroom.js也行:http://www.bootcss.com/p/headroom.js/