【POJ1149&BZOJ1280】PIGS(最大流)

题意:Emmy在一个养猪场工作。这个养猪场有M个锁着的猪圈,但Emmy并没有钥匙。

顾客会到养猪场来买猪,一个接着一个。每一位顾客都会有一些猪圈的钥匙,他们会将这些猪圈打开并买走固定数目的猪。

所有顾客有的钥匙和他们需要买猪的数量在事先都告诉了Emmy,于是Emmy要订一个计划,使得卖出去的猪最多。

买卖的过程是这样的:一个顾客前来,并打开所有他可以打开的猪圈。

然后Emmy从这些猪圈里牵出固定数目的猪卖给顾客(最多只能和顾客需要数相等),并可以重新安排这些开着的猪圈中的猪。

每个猪圈可以存放任意数目的猪。 写一个程序,使得Emmy能够卖出去尽可能多的猪。

1 ≤ M ≤ 1000
1 ≤ N ≤ 100

思路:RYZ作业

考虑到如果有两个人拥有同一个猪圈的钥匙,则前一个人可以分配任意(不能超过他自己能拿到上限)数量的猪给后一个人

前一个人——>后一个人 OO

又发现他们之间不用全部两两连边,只需要按到来顺序,相邻连边

猪圈其实就是从源点出来的容量上限

源点——>某猪圈第一个人 a[i]

最后还有每个人购买的限制

每个人——>汇点 b[i]

也是网络流经典模型之一

  1 var head,vet,next,len,dis,gap,fan:array[0..110000]of longint;
  2     a,last:array[1..10000]of longint;
  3     m,n,i,j,x,y,z,tot,s,source,src:longint;
  4 
  5 procedure add(a,b,c:longint);
  6 begin
  7  inc(tot);
  8  next[tot]:=head[a];
  9  vet[tot]:=b;
 10  len[tot]:=c;
 11  head[a]:=tot;
 12 
 13  inc(tot);
 14  next[tot]:=head[b];
 15  vet[tot]:=a;
 16  len[tot]:=0;
 17  head[b]:=tot;
 18 end;
 19 
 20 function min(x,y:longint):longint;
 21 begin
 22  if x<y then exit(x);
 23  exit(y);
 24 end;
 25 
 26 function dfs(u,aug:longint):longint;
 27 var e,v,t,flow,val:longint;
 28 begin
 29  if u=src then exit(aug);
 30  e:=head[u]; flow:=0; val:=s-1;
 31  while e<>0 do
 32  begin
 33   v:=vet[e];
 34   if len[e]>0 then
 35   begin
 36    if dis[u]=dis[v]+1 then
 37    begin
 38     t:=dfs(v,min(len[e],aug-flow));
 39     len[e]:=len[e]-t;
 40     len[fan[e]]:=len[fan[e]]+t;
 41     flow:=flow+t;
 42     if dis[source]>=s then exit(flow);
 43     if aug=flow then break;
 44    end;
 45    val:=min(val,dis[v]);
 46   end;
 47   e:=next[e];
 48  end;
 49  if flow=0 then
 50  begin
 51   dec(gap[dis[u]]);
 52   if gap[dis[u]]=0 then dis[source]:=s;
 53   dis[u]:=val+1;
 54   inc(gap[dis[u]]);
 55  end;
 56  exit(flow);
 57 end;
 58 
 59 function maxflow:longint;
 60 var ans:longint;
 61 begin
 62  fillchar(gap,sizeof(gap),0);
 63  fillchar(dis,sizeof(dis),0);
 64  gap[0]:=s; ans:=0;
 65  while dis[source]<s do ans:=ans+dfs(source,maxlongint);
 66  exit(ans);
 67 end;
 68 
 69 begin
 70  assign(input,'bzoj1280.in'); reset(input);
 71  assign(output,'bzoj1280.out'); rewrite(output);
 72  readln(m,n);
 73  for i:=1 to m do read(a[i]);
 74  for i:=1 to 110000 do
 75   if i and 1=1 then fan[i]:=i+1
 76    else fan[i]:=i-1;
 77  source:=n+1; src:=n+2; s:=n+2;
 78  for i:=1 to n do
 79  begin
 80   read(x);
 81   for j:=1 to x do
 82   begin
 83    read(y);
 84    if last[y]=0 then
 85    begin
 86     add(source,i,a[y]);
 87     last[y]:=i;
 88    end
 89     else
 90     begin
 91      add(last[y],i,maxlongint);
 92      last[y]:=i;
 93     end;
 94   end;
 95   read(z);
 96   add(i,src,z);
 97  end;
 98  writeln(maxflow);
 99  close(input);
100  close(output);
101 end.

 

posted on 2017-03-03 11:21  myx12345  阅读(150)  评论(0编辑  收藏  举报

导航