这道题要谈很多;

首先,第一问等会我另外说一下;

第二问比较难想,首先我们的考虑两人的最优策略是什么

对于Bob,我们令分配了x条边的费用,则我们要最大化

ans=Σ(i=1 to x) flow[i] * p/x  (flow[i]为选择的边)

显然ans<=x*maxflow[i]*p/x=maxflow[i]*p

显然ans最大的方案就是将费用全部分配到实际流量最大的那条边上去

这样Alice的方案也明确了,就是在维持最大流不变的前提下,是实际流量最大的那条边最小

对于这类最小化最大的问题,我们不难想到二分答案,二分网络流上界流量

但请注意,有没有从题目保留的精度想到什么呢?

对,这道题流量可以是实数,

对于任意实数的网络流是不可做的,但是在一定精度范围内就照样可行;

照样就没什么问题了

这里说下我发现我以前写的最大流sap是不够好的

没加当前弧优化,之前很多题没TLE真是万幸;

在bzoj2127(之后放在一个专题写)中体现的特别明显,如果只用sap+gap妥妥TLE

用了之后1s多跑完……

这里给出最终的最大流写法(sap+gap+cur)

 const inf=;
      ok=1e-6;  //控制精读
type node=record
       next,point:longint;
       flow:double;
     end; var edge:array[..] of node;
    cur,numh,p,h,pre:array[..] of longint;
    w,x,y:array[..] of longint;
    d:array[..] of double;
    l,r,mid,ans1,ans2:double;
    t,len,i,n,m:longint; function min(a,b:double):double;
  begin
    if a>b then exit(b) else exit(a);
  end; procedure add(x,y:longint;f:double);
  begin
    inc(len);
    edge[len].flow:=f;
    edge[len].point:=y;
    edge[len].next:=p[x];
    p[x]:=len;
  end; function sap(k:double):double;  //带当前弧优化
  var u,i,j,tmp,q:longint;
      neck:double;
      flag:boolean;
  begin
    len:=-;
    fillchar(p,sizeof(p),);
    for i:= to m do
    begin
      add(x[i],y[i],min(k,w[i]));
      add(y[i],x[i],);
    end;
    fillchar(numh,sizeof(numh),);
    fillchar(h,sizeof(h),);
    numh[]:=n;
    u:=;
    neck:=inf;
    sap:=;
    cur:=p;
    while h[]<n do
    begin
      d[u]:=neck;
      flag:=false;
      i:=cur[u];
      while i<>- do
      begin
        j:=edge[i].point;
        if (edge[i].flow>) and (h[u]=h[j]+) then
        begin
          flag:=true;
          cur[u]:=i;
          pre[j]:=u;
          neck:=min(neck,edge[i].flow);
          u:=j;
          if u=n then
          begin
            sap:=sap+neck;
            while u<> do
            begin
              u:=pre[u];
              j:=cur[u];
              edge[j].flow:=edge[j].flow-neck;
              edge[j xor ].flow:=edge[j xor ].flow+neck;
            end;
            neck:=inf;  //勿忘1
          end;
          break;
        end;
        i:=edge[i].next;
      end;
      if not flag then
      begin
        dec(numh[h[u]]);
        if numh[h[u]]= then exit;
        tmp:=n;
        i:=p[u];
        q:=;
        while i<>- do
        begin
          j:=edge[i].point;
          if (tmp>h[j]) and (edge[i].flow>) then
          begin
            q:=i;
            tmp:=h[j];
          end;
          i:=edge[i].next;
        end;
        h[u]:=tmp+;
        cur[u]:=q;     //勿忘2
        inc(numh[h[u]]);
        if u<> then
        begin
          u:=pre[u];
          neck:=d[u];   //记录当前瓶颈边的作用
        end;
      end;
    end;
  end; begin
  readln(n,m,t);
  for i:= to m do
  begin
    readln(x[i],y[i],w[i]);
    if r<w[i] then r:=w[i];
  end;
  l:=;
  ans1:=sap(r);
  while r-l>ok do   //实数范围内的二分答案
  begin
    mid:=(l+r)/;
    if abs(ans1-sap(mid))<ok then r:=mid
    else l:=mid;
  end;
  writeln(ans1::);
  writeln(r*t::);
end.

bzoj3130的更多相关文章

  1. 【BZOJ3130】费用流(最大流,二分)

    [BZOJ3130]费用流(最大流,二分) 题面 Description Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一 ...

  2. 【二分答案】【最大流】bzoj3130 [Sdoi2013]费用流

    二分最大的边的cap,记作Lim. 把所有的边的cap设为min(Lim,cap[i]). Bob一定会把单位费用加到最大边上. #include<cstdio> #include< ...

  3. BZOJ3130: [Sdoi2013]费用流[最大流 实数二分]

    3130: [Sdoi2013]费用流 Time Limit: 10 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 960  Solved: 5 ...

  4. BZOJ-3130 费用流 (听题目胡扯丶裸最大流) 二分判定+最大流+实数精度乱搞

    DCrusher爷喜欢A我做的水题,没办法,只能A他做不动的题了.... 3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec ...

  5. BZOJ3130 [Sdoi2013]费用流

    AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=3130 这题codevs上也有,不过数据挂了[要A得看discuss]. 题目大意: Ali ...

  6. luogu3305/bzoj3130 费用流 (二分答案+dinic)

    Bob肯定想挑一个流量最大的边,然后把所有的费用都加给它呗 那Alice就让流量最大的边尽量小呗 那就二分一下答案再dinic呗 #include<bits/stdc++.h> #defi ...

  7. bzoj千题计划133:bzoj3130: [Sdoi2013]费用流

    http://www.lydsy.com/JudgeOnline/problem.php?id=3130 第一问就是个最大流 第二问: Bob希望总费用尽量大,那肯定是把所有的花费加到流量最大的那一条 ...

  8. 【bzoj3130】[Sdoi2013]费用流 二分+网络流最大流

    题目描述 Alice和Bob做游戏,给出一张有向图表示运输网络,Alice先给Bob一种最大流方案,然后Bob在所有边上分配总和等于P的非负费用.Alice希望总费用尽量小,而Bob希望总费用尽量大. ...

  9. BZOJ3130 [Sdoi2013]费用流 【网络流 + 二分】

    题目 Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量.一个合法的网络流方案必须满足:(1)每 ...

随机推荐

  1. WPF 中,如何使用自定义的resources

    第一步,先自己自定义一个Resources 1.新建一个xaml文件,在其中自定义好自己的Resources 这个Resource 的根节点是 <ResourceDictionary xmlns ...

  2. mysql空间数据相关操作

    建表语句: CREATE TABLE ts.points ( name ) NOT NULL, location POINT NOT NULL, description ) ); 添加记录如下: IN ...

  3. C# 调用load事件

    在一个函数或者事件中调用另外的事件,例如调用Load事件 private void EventForm_Load(object sender, EventArgs e) { //相关内容 } priv ...

  4. android开发之GenyMotion与intelliJ的配置

    (注意:这是在你的电脑上安装了intelliJ和安卓SDK后才进行的工作,如果没有intelliJ和安卓SDK,请先安装以上两样东西) 号称史上最快乐的模拟器GenyMotion,试一下. 第一步:下 ...

  5. 跟我一起学Vim补全神级插件--YouCompleteMe

    最近重拾Vim,编译部署来补全插件YCM,这个插件的补全效果和在写C代码的时候的自动提示错误信息等还是十分棒的,写点心得下来,也算给自己做个备忘. 快速安装: 首先参考我的.vimrc配置,用Vund ...

  6. Linux Vi的使用

    1.vi使用三模式:一般模式,插入模式,命令模式 保存和退出vi: 命令模式下 :w 保存 :w 新文件 保存到新文件 类似另存为,新文件存在,报错 :w! 新文件 保存到新文件,新文件存在,覆盖 : ...

  7. Sublime Text 3的快捷键

    Sublime Text 3是一个非常了不起的软件,它不仅具有令人难以置信的内置功能(多行编辑和VIM模式),而且还支持插件.代码片段和其它许多东西. 今天,我们来总结一下Sublime Text 3 ...

  8. Windows Phone 8 开发初体验

    Windows Phone 8 是当前除了Android.IPhone之外,第3大智能手机运行平台.作为微软技术的忠实fans,一直关注和跟进微软技术的最新进展.这里就给大家简单介绍一下,如何进行Wi ...

  9. memcached全面剖析--5

    memcached的应用和兼容程序 mixi案例研究 mixi在提供服务的初期阶段就使用了memcached. 随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memca ...

  10. Android 之 悬浮窗

    昨天研究Android的悬浮窗,遇到一个问题,研究了一天,总算找到结症了,原因非常坑人..... 问题是这样的,我想要将悬浮窗展现在桌面或其他应用之上,我的开发机子用的是MIUI,结果发现在机子上无论 ...