bzoj3130
这道题要谈很多;
首先,第一问等会我另外说一下;
第二问比较难想,首先我们的考虑两人的最优策略是什么
对于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的更多相关文章
- 【BZOJ3130】费用流(最大流,二分)
[BZOJ3130]费用流(最大流,二分) 题面 Description Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一 ...
- 【二分答案】【最大流】bzoj3130 [Sdoi2013]费用流
二分最大的边的cap,记作Lim. 把所有的边的cap设为min(Lim,cap[i]). Bob一定会把单位费用加到最大边上. #include<cstdio> #include< ...
- BZOJ3130: [Sdoi2013]费用流[最大流 实数二分]
3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 960 Solved: 5 ...
- BZOJ-3130 费用流 (听题目胡扯丶裸最大流) 二分判定+最大流+实数精度乱搞
DCrusher爷喜欢A我做的水题,没办法,只能A他做不动的题了.... 3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec ...
- BZOJ3130 [Sdoi2013]费用流
AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=3130 这题codevs上也有,不过数据挂了[要A得看discuss]. 题目大意: Ali ...
- luogu3305/bzoj3130 费用流 (二分答案+dinic)
Bob肯定想挑一个流量最大的边,然后把所有的费用都加给它呗 那Alice就让流量最大的边尽量小呗 那就二分一下答案再dinic呗 #include<bits/stdc++.h> #defi ...
- bzoj千题计划133:bzoj3130: [Sdoi2013]费用流
http://www.lydsy.com/JudgeOnline/problem.php?id=3130 第一问就是个最大流 第二问: Bob希望总费用尽量大,那肯定是把所有的花费加到流量最大的那一条 ...
- 【bzoj3130】[Sdoi2013]费用流 二分+网络流最大流
题目描述 Alice和Bob做游戏,给出一张有向图表示运输网络,Alice先给Bob一种最大流方案,然后Bob在所有边上分配总和等于P的非负费用.Alice希望总费用尽量小,而Bob希望总费用尽量大. ...
- BZOJ3130 [Sdoi2013]费用流 【网络流 + 二分】
题目 Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量.一个合法的网络流方案必须满足:(1)每 ...
随机推荐
- as3判断XML是否合法
XML是否合法 在我认为 XML的标签成对 并且根标签外边没有其他东西 以下是合法的 <?xml version="1.0" encoding="utf-8&quo ...
- jQuery 源码分析6: jQuery 基本静态方法(二)
jQuery.extend({ // 遍历obj的所有值 // args 这参数只能内部调用的会用到 // 注意到,如果回调函数调用失败会直接跳出并中止遍历 // 当有args数组时,使用apply调 ...
- android Locat工作日志的使用
#3.Logcat日志工具的使用 日志的等级: error:最高等级,错误信息,红色 warn:比较高,警告信息,橙色 debug:较高,调试信息,蓝色 info:一般,一般信息,绿色 verbose ...
- Codevs 1001 舒适的路线 2006年 NOIP全国联赛提高组
1001 舒适的路线 2006年 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观 ...
- libjingle线程机制
libjingle包装了所有的线程,包括signaling thread,worker thread, 和其它任何线程,用talk_base::Thread来包装.所有的 Thread对象由Threa ...
- 【nodemailer】 之邮件附件
nodemailer 续 之前对nodemailer做了一个简单的了解,这篇文章主要研究一下如何添加附加文件 测试代码 //Created by yyrdl on 2015/10/2. var nod ...
- QtSQL学习笔记(3)- 执行SQL语句
QSqlQuery类提供了一个用于执行SQL语句和浏览查询的结果集的接口. QSqlQueryModel和QSqlTableModel类提供了一个用于访问数据库的高级接口,这将在下一节介绍.如果你不熟 ...
- PH获取当前url路径及服务器路径汇总 (url 获取当前路径 服务器路径)
以下是整理的一些, php中获取路径的小知识, 希望对你有所帮助! 1,$_SERVER["QUERY_STRING"] 说明:查询(query)的字符串 2,$_SERVER[& ...
- 会话控制:cookie和session基础学习笔记
在多次HTTP连接间维护用户与同一用户发出的不同请求之间关联的情况称为维护一个会话(session) 我们可以简单理解为浏览器的开关. 其实对cookie和session也是主要为curd操作 coo ...
- ecshop用户中心订单详情增加快递单物流信息查询显示的功能
1,themes\default\user_transaction.dwt 找到: <!--{if $action eq order_detail} --> 在下面一行加入: <st ...