【bzoj3130】[Sdoi2013]费用流 二分+网络流最大流
题目描述
Alice和Bob做游戏,给出一张有向图表示运输网络,Alice先给Bob一种最大流方案,然后Bob在所有边上分配总和等于P的非负费用。Alice希望总费用尽量小,而Bob希望总费用尽量大。求两人都采取最优策略的情况下最大流及总费用。
输入
第一行三个整数N,M,P。N表示给定运输网络中节点的数量,M表示有向边的数量,P的含义见问题描述部分。为了简化问题,我们假设源点S是点1,汇点T是点N。
接下来M行,每行三个整数A,B,C,表示有一条从点A到点B的有向边,其最大流量是C。
输出
第一行一个整数,表示最大流的值。
第二行一个实数,表示总费用。建议选手输出四位以上小数。
样例输入
3 2 1
1 2 10
2 3 15
样例输出
10
10.000
题解
二分+网络流最大流
显然对于Alice给出的一种方案,Bob只需要在流量最大的边上设置费用P,其它边费用为0,即可使费用最大。
所以Alice要使费用尽量小,就需要使流量最大的边的流量最小。
先跑一遍最大流得出第一问的答案。然后二分最大流量,对于一条边,将其容量设置为 min(原图中流量,mid) ,跑最大流,如果最大流等于原图的最大流则可行,否则不可行。
最后的答案就是mid*P。
我才不会告诉你们第二问puts("nan")可过呢
#include <queue>
#include <cstdio>
#include <cstring>
#define N 110
#define M 2010
using namespace std;
queue<int> q;
int m , px[M] , py[M] , head[N] , to[M] , next[M] , cnt , s , t , dis[N];
double pz[M] , val[M];
inline void add(int x , int y , double z)
{
to[++cnt] = y , val[cnt] = z , next[cnt] = head[x] , head[x] = cnt;
to[++cnt] = x , val[cnt] = 0 , next[cnt] = head[y] , head[y] = cnt;
}
bool bfs()
{
int x , i;
memset(dis , 0 , sizeof(dis));
while(!q.empty()) q.pop();
dis[s] = 1 , q.push(s);
while(!q.empty())
{
x = q.front() , q.pop();
for(i = head[x] ; i ; i = next[i])
{
if(val[i] && !dis[to[i]])
{
dis[to[i]] = dis[x] + 1;
if(to[i] == t) return 1;
q.push(to[i]);
}
}
}
return 0;
}
double dinic(int x , double low)
{
if(x == t) return low;
double temp = low , k;
int i;
for(i = head[x] ; i ; i = next[i])
{
if(val[i] && dis[to[i]] == dis[x] + 1)
{
k = dinic(to[i] , min(temp , val[i]));
if(!k) dis[to[i]] = 0;
val[i] -= k , val[i ^ 1] += k;
if(!(temp -= k)) break;
}
}
return low - temp;
}
double solve(double mid)
{
int i;
double ans = 0;
memset(head , 0 , sizeof(head)) , cnt = 1;
for(i = 1 ; i <= m ; i ++ ) add(px[i] , py[i] , min(pz[i] , mid));
while(bfs()) ans += dinic(s , 1e9);
return ans;
}
int main()
{
int n , i , cnt = 50;
double l = 0 , r = 1e9 , mid , flow , p;
scanf("%d%d%lf" , &n , &m , &p) , s = 1 , t = n;
for(i = 1 ; i <= m ; i ++ ) scanf("%d%d%lf" , &px[i] , &py[i] , &pz[i]);
printf("%.0lf\n" , flow = solve(1e9));
while(cnt -- )
{
mid = (l + r) / 2;
if(solve(mid) == flow) r = mid;
else l = mid;
}
printf("%.4lf\n" , r * p);
return 0;
}
【bzoj3130】[Sdoi2013]费用流 二分+网络流最大流的更多相关文章
- 【bzoj1822】[JSOI2010]Frozen Nova 冷冻波  计算几何+二分+网络流最大流
		
题目描述 WJJ喜欢“魔兽争霸”这个游戏.在游戏中,巫妖是一种强大的英雄,它的技能Frozen Nova每次可以杀死一个小精灵.我们认为,巫妖和小精灵都可以看成是平面上的点. 当巫妖和小精灵之间的直线 ...
 - 【bzoj1733】[Usaco2005 feb]Secret Milking Machine 神秘的挤奶机  二分+网络流最大流
		
题目描述 Farmer John is constructing a new milking machine and wishes to keep it secret as long as possi ...
 - 【bzoj1532】[POI2005]Kos-Dicing  二分+网络流最大流
		
题目描述 Dicing 是一个两人玩的游戏,这个游戏在Byteotia非常流行. 甚至人们专门成立了这个游戏的一个俱乐部. 俱乐部的人时常在一起玩这个游戏然后评选出玩得最好的人.现在有一个非常不走运的 ...
 - 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 ...
 - bzoj千题计划133:bzoj3130: [Sdoi2013]费用流
		
http://www.lydsy.com/JudgeOnline/problem.php?id=3130 第一问就是个最大流 第二问: Bob希望总费用尽量大,那肯定是把所有的花费加到流量最大的那一条 ...
 - POJ 2455 Secret Milking Machine(搜索-二分,网络流-最大流)
		
Secret Milking Machine Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9658 Accepted: ...
 - BZOJ3130 [Sdoi2013]费用流  【网络流 + 二分】
		
题目 Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量.一个合法的网络流方案必须满足:(1)每 ...
 - BZOJ3130: [Sdoi2013]费用流(二分,最大流)
		
Description Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量.一个合法的网络 ...
 
随机推荐
- 北京Uber优步司机奖励政策(4月16日)
			
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
 - vue 过滤器filters的使用以及常见报错小坑(Failed to resolve filter)
			
今天使用vue 过滤器中发现一个小坑,网上查到的大都是不正确的解决方法,故分享给大家: 原错误代码: // 过滤器 filter:{ FdishList:function(value){ if (!v ...
 - Retinex图像增强和暗通道去雾的关系及其在hdr色调恢复上的应用
			
很多人都认为retinex和暗通道去雾是八杆子都打不着的增强算法.的确,二者的理论.计算方法都完全迥异,本人直接从二者的公式入手来简单说明一下,有些部分全凭臆想,不对之处大家一起讨论. 首先,为描述方 ...
 - 关于nginx反向代理504 gateway time-out配置
			
问题描述: 使用nginx的默认配置用作后端处理服务的反向代理,针对处理时间超过1分钟的请求,返回504 gateway time-out,但后端服务还在执行中. 原因分析: nginx代理默认超时时 ...
 - dotweb now released to Version 1.5
			
dotweb released to Version 1.5!!https://github.com/devfeel/dotweb What's new? 重要:go版本适配升级为1.9+ New f ...
 - selenium自动化之定位多个元素
			
前面我们讲的都是如何定位单个元素,下面讲下怎么去定位多个元素,并且输出文本. 以百度为例:获取标红的这一组元素的文本 这里我用到的是xpath来定位的://div[@id="u1" ...
 - flexbox的应用
			
2009年,display: box 就已经出现,但是直到IE11的发布,全部的主流浏览器才统一支持新的用法display: flex. 这里只说应用,浏览器的兼容处理会附在文章的末尾. 起步 在现代 ...
 - javascript 强制转换规则 boolean 布尔值类型
			
摘自 <你不知道的Javascript(中卷)> p55 一句话简述, 假值表以外的值均可以认为是真值,部分浏览器可能自定义了假值表以外的假值,并不符合W3C规范,需要特殊对待. 首先也是 ...
 - 这才是球王应有的技艺,他就是C罗
			
四年一度的世界杯在本周四拉开了帷幕,俄罗斯以5:0碾压沙特阿拉伯,让我们惊呼战斗名族的强大,其后的摩洛哥VS伊朗,摩洛哥前锋布哈杜兹将足球顶入自家球门,这......咳,咳,本来是为了解围,没想到成就 ...
 - 【ZABBIX】Zabbix触发器的告警原理及创建方法
			
概述: 触发器中的表达式使用很灵活,我们可以创建一个复杂的逻辑测试监控,触发器表达式形式如下: {<server>:<key>.<function>(& ...