AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=3130

这题codevs上也有,不过数据挂了[要A得看discuss]。

题目大意:

Alice来弄一条最大流,Bob来给Alice弄好的最大流定权值。

定权值的方法是给没条边定一个值wi,然后wi*flow(i)的和就是总的费用,但要求所有wi之和为p。

现在Bob希望最后的费用最大,即对于每一种最大流方案都会有一种最大的定值方案。

Alice则希望花费最小,即选出一种最大流方案,使得这种方案的最大定值是所有最大流方案中最小的。

求最大流,及这个最小的最大定值。

首先我们先从Bob的角度出发。

怎么给一种最大流方案定值就能最大呢?

显然是给最大流中流量最大的边订上p的值就可以了。

因为最后也是加法,然后满足分配率,然后随便证一下,感受一下就是对的了。

然后从Alice的角度来想,恩不就是让流量最大的边最小么?...

然后就限制流量跑最大流啊,如果和原来相同就可以了。

这个流量限制就是典型的二分咯...不过注意往常的网络流都是跑整数流量,但是这题不是,我们要实数二分最大流量

因为往常边都是整数的边,最大流跑整数的一定可以跑出来,不过现在毕竟限流的情况,那么我们要跑小数咯...

如果你还不信,给你一个样例好了[来自ZYF-ZYF]:

所以呢= =大家注意精度控制好了...不懂看看代码也行。

#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm> using namespace std; const int maxn=;
const int maxm=;
const int INF=0x3f3f3f3f;
const double eps=1e-; struct Node{
int data,next;
double low;
}node[maxm<<]; #define now node[point].data
#define www node[point].low
#define then node[point].next struct Edge{
int u,v;
double w;
}edge[maxm]; int n,m,p,cnt;
int s,t;
double ans;
int dis[maxn],que[maxn];
int head[maxn],cur[maxn]; void add(int u,int v,double w){
node[cnt].data=v;node[cnt].next=head[u];node[cnt].low=w;head[u]=cnt++;
node[cnt].data=u;node[cnt].next=head[v];node[cnt].low=;head[v]=cnt++;
} bool BFS(){
memset(dis,-,sizeof(dis));
int H=,T=;que[]=;dis[]=;
while(H<T){
H++;
for(int point=head[que[H]];point!=-;point=then)
if(www>eps && dis[now]<){
dis[now]=dis[que[H]]+;
que[++T]=now;
}
}
return dis[t]>;
} double dfs(int x,double low){
if(x==t) return low;
double Low;
for(int &point=cur[x];point!=-;point=then)
if(www>eps && dis[now]==dis[x]+){
Low=dfs(now,min(low,www));
if(Low>eps){
www-=Low,node[point^].low+=Low;
return Low;
}
}
return ;
} double check(double mid){
cnt=;
for(int i=;i<=n;i++) head[i]=-;
for(int i=;i<=m;i++)
add(edge[i].u,edge[i].v,min(edge[i].w,mid)); double flag,sum=;
while(BFS()){
memcpy(cur,head,sizeof(head));
while((flag=dfs(s,INF))>eps)
sum+=flag;
}
return sum;
} int main(){
#ifndef ONLINE_JUDGE
freopen("3130.in","r",stdin);
freopen("3130.out","w",stdout);
#endif
int u,v,w;
double l=,r=,mid; scanf("%d%d%d",&n,&m,&p);
s=,t=n;
for(int i=;i<=n;i++) head[i]=-;
for(int i=;i<=m;i++)
scanf("%d%d%lf",&edge[i].u,&edge[i].v,&edge[i].w),r=max(r,edge[i].w); ans=check(r);
while(r-l>eps){
mid=(l+r)/;
if(fabs(ans-check(mid))<eps) r=mid;
else l=mid;
} printf("%.0lf\n%.5lf",ans,l*p); return ;
}

BZOJ3130 [Sdoi2013]费用流的更多相关文章

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

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

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

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

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

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

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

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

  5. BZOJ3130: [Sdoi2013]费用流(二分,最大流)

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

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

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

  7. P3305 [SDOI2013]费用流

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

  8. luogu P3305 [SDOI2013]费用流

    题目链接 bz似乎挂了... luogu P3305 [SDOI2013]费用流 题解 dalao告诉我,这题 似乎很水.... 懂了题目大意就可以随便切了 问1,最大流 问2,二分最大边权求,che ...

  9. BZOJ 3130: [Sdoi2013]费用流 网络流+二分

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

随机推荐

  1. luigi学习2-在hadoop上运行Top Artists

    一.AggregateArtistsHadoop class AggregateArtistsHadoop(luigi.contrib.hadoop.JobTask): date_interval = ...

  2. Mongod(5):启动命令mongod参数说明

    Mongodb启动命令mongod参数说明(http://blog.csdn.net/fdipzone/article/details/7442162) mongod的主要参数有: 基本配置 ---- ...

  3. PHP常用函数和常见疑难问题解答

    PHP常用库函数介绍 一.PHP字符串操作常用函数 1.确定字符串长度  int strlen(string str) 2.比较两个字符串 a. strcmp函数对两个字符串进行二进制安全的比较,并区 ...

  4. 利用JS实现的根据经纬度计算地球上两点之间的距离

      最近用到了根据经纬度计算地球表面两点间距离的公式,然后就用JS实现了一下. 计算地球表面两点间的距离大概有两种办法. 第一种是默认地球是一个光滑的球面,然后计算任意两点间的距离,这个距离叫做大圆距 ...

  5. php的swoole扩展中onclose和onconnect接口不被调用的问题

    在用swoole扩展写在线聊天例子的时候遇到一个问题,查了不少资料,现在记录于此. 通过看swoole_server的接口文档,回调注册接口on中倒是有明确的注释: * swoole_server-& ...

  6. [IIS] eset/Restart/Recycling/Refresh 的区别

    iisreset -- 对象是整个IIS服务器,这个操作会先停止万维网的服务(World Wide Web Publishing Service)然后在重启此服务,因此所有的网站都会先停止服务然后在重 ...

  7. phpcms v9 中get的mysql查询表某字段最大值数据,表某字段不重复数据

    直切正题 1.表tb中字段num最大的数据 {pc:get $sql="select * from tb where num=(select MAX(num) from tb)"} ...

  8. 往Android SDCard中读写入数据

    一.用Environment (写) 1.API获取sdcard的路径 File path=Environment.getExternalStorageDirectory(); path=new Fi ...

  9. Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录)

    Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录) 作者:王可利(Star·星星) 效果图: 代码如下: class Star8 { public static void m ...

  10. VBA赋值给指定单元格

    这是一个Range对象基本操作实例,对指定单元格赋值,然后使用弹窗获取值. 代码如下: Sub test1() Worksheets( MsgBox "工作表Sheet1内单元格A5中的值为 ...