【JZOJ3215】【SDOI2013】费用流
╰( ̄▽ ̄)╭
对于一张给定的 运输网络 ,Alice 先确定一个最大流 ,如果有多种解, Alice 可以任选一种; 之后 Bob在每条边上分配单位花费 (单位花费必须是非负实数), 要求所有边的单位花费之和等于 P。总费用等于每一条边 的实际流量乘以该边的单位花费。 需要注意到, Bob在分配单位花费之前,已经知道Alice 所给出的最大流方案。
现在 Alice 希望总费用尽量小,而Bob希望总费用尽量大。我们想知道, 如 果两个人都执行最优策略 ,最大流的值和总费用分别为多少。
对于 100% 的测试数据: N≤100 ,M≤1000 。
对于 100% 的测试数据: 所有点的编号在 1..N 范围内。 1≤每条边 的最大 流 量≤50000 。1≤P≤10 。给定运输网络中不会有起点和 终点 相同的边。
(⊙ ▽ ⊙)
显然Bob要把所有费用全部分配给实际流量最大的边。
所以Alice在满足最大流最大之余,使得流量最大的边最小。
所以二分后再用最大流判断就可以了。
( ̄~ ̄)
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<math.h>
#include<string.h>
#define ll long long
#define eps 10e-7
using namespace std;
const char* fin="ex3215.in";
const char* fout="ex3215.out";
const int inf=0x7fffffff;
const int maxn=2007;
int n,m,n1,i,j,k;
int a[maxn][2],fi[maxn],ne[maxn],la[maxn],tot;
double l,r,mid,va[maxn],b[maxn],Ans;
int bz[maxn],card[maxn];
double Abs(double a){
return a>0?a:-a;
}
void add_line(int a,int b,double c){
tot++;
ne[tot]=fi[a];
la[tot]=b;
va[tot]=c;
fi[a]=tot;
}
void add(int a,int b,double c){
add_line(a,b,c);
add_line(b,a,0);
}
double gap(int v,double flow){
int i,k;
double use=0,j;
if (v==n) return flow;
for (k=fi[v];k;k=ne[k])
if (bz[la[k]]+1==bz[v] && Abs(va[k])>eps){
j=gap(la[k],min(va[k],flow-use));
use+=j;
va[k]-=j;
va[k^1]+=j;
if (Abs(flow-use)<eps || bz[1]==n) return use;
}
if (!--card[bz[v]]) bz[1]=n;
card[++bz[v]]++;
return use;
}
double flow(){
double ans=0;
memset(card,0,sizeof(card));
memset(bz,0,sizeof(bz));
card[0]=n;
while (bz[1]<n){
ans+=gap(1,inf);
}
return ans;
}
bool judge(double MAX){
int i,j,k;
memset(fi,0,sizeof(fi));
tot=1;
for (i=1;i<=m;i++) add(a[i][0],a[i][1],min(MAX,b[i]));
return Abs(flow()-Ans)<eps;
}
int main(){
scanf("%d%d%d",&n,&m,&n1);
tot=1;
for (i=1;i<=m;i++) scanf("%d%d%lf",&a[i][0],&a[i][1],&b[i]),add(a[i][0],a[i][1],b[i]);
Ans=flow();
l=0;
r=50000;
while (r-l>eps){
mid=(l+r)/2;
if (judge(mid)) r=mid;
else l=mid;
}
printf("%d\n%.4lf",int(Ans+eps),l*n1 );
return 0;
}
(⊙v⊙)
要注意的是网络流的实现时的问题:
double gap(int v,double flow){
int i,k;
double use=0,j;
if (v==n) return flow;
for (k=fi[v];k;k=ne[k])
if (bz[la[k]]+1==bz[v] && Abs(va[k])>eps){
j=gap(la[k],min(va[k],flow-use));
use+=j;
va[k]-=j;
va[k^1]+=j;
if (Abs(flow-use)<eps || bz[1]==n) return use;
}
if (!--card[bz[v]]) bz[1]=n;
card[++bz[v]]++;
return use;
}
1.三个中两个return返回的都是use;
2.当use==flow使,直接返回use;
3.到达汇点,返回flow。
【JZOJ3215】【SDOI2013】费用流的更多相关文章
- BZOJ3130: [Sdoi2013]费用流[最大流 实数二分]
3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 960 Solved: 5 ...
- bzoj千题计划133:bzoj3130: [Sdoi2013]费用流
http://www.lydsy.com/JudgeOnline/problem.php?id=3130 第一问就是个最大流 第二问: Bob希望总费用尽量大,那肯定是把所有的花费加到流量最大的那一条 ...
- P3305 [SDOI2013]费用流
题目描述 Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量. 一个合法的网络流方案必须满足: ...
- luogu P3305 [SDOI2013]费用流
题目链接 bz似乎挂了... luogu P3305 [SDOI2013]费用流 题解 dalao告诉我,这题 似乎很水.... 懂了题目大意就可以随便切了 问1,最大流 问2,二分最大边权求,che ...
- BZOJ 3130: [Sdoi2013]费用流 网络流+二分
3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 1230 Solved: ...
- BZOJ 3130: [Sdoi2013]费用流 网络流 二分 最大流
https://www.lydsy.com/JudgeOnline/problem.php?id=3130 本来找费用流的题,权当复习一下网络流好了. 有点麻烦的是double,干脆判断大小或者二分增 ...
- BZOJ3130 [Sdoi2013]费用流
AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=3130 这题codevs上也有,不过数据挂了[要A得看discuss]. 题目大意: Ali ...
- bzoj 3130 [Sdoi2013]费用流(二分,最大流)
Description Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量.一个合法的网络 ...
- [SDOI2013]费用流
然而这是一道网络流... 如果满足Bob,使总费用最大: 设最大流的每条边流量(不是容量)为w[i],分配到每条边的费用为p[i],最大流量为wmax,p[i]的和为P 那么显然w[i] * p[i] ...
- Luogu P3305 [SDOI2013]费用流 二分 网络流
题目链接 \(Click\) \(Here\) 非常有趣的一个题目. 关键结论:所有的单位费用应该被分配在流量最大的边上. 即:在保证最大流的前提下,使最大流量最小.这里我们采用二分的方法,每次判断让 ...
随机推荐
- centos部署jeecms
首先下载安装包apache-tomcat-8.5.40.tar.gz jdk-8u211-linux-x641.rpm jeecmsv9.war 已经在WEB-INF/config/jdbc.prop ...
- 01_jQuery初识
1.为什么要学习jQuery?做同样的事情,jQuery写起来极其简练(write less , do more) 2.jQuery是什么?jQuery相当于Python的第三方模块,原生JS DOM ...
- 在当前目录打开DOS命令行窗口
[step1]选中文件夹 [step2]shift + 鼠标右键
- 2018-10-31-win10-uwp-使用-asp-dotnet-core-做图床服务器客户端
title author date CreateTime categories win10 uwp 使用 asp dotnet core 做图床服务器客户端 lindexi 2018-10-31 14 ...
- bzoj1706 relays 奶牛接力跑 线性代数
题目描述 FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼项目.至于进行接力跑的地点 自然是在牧场中现有的T(2 <= T <= 100) ...
- 如何访问linux服务器上的mysql8.0
首先安装好了mysql-connector 1.1. 下载: 官网下载zip包,我下载的是64位的: 下载地址:https://dev.mysql.com/downloads/mysql/ 下载zip ...
- megacli在线raid构建详解(转载自用)
版权声明:本文为博主原创文章,未经博主允许不得转载,转载附上原文链接即可. https://blog.csdn.net/GX_1_11_real/article/details/83213959 ht ...
- jeecms框架单点登录功能的实现
单点登录的功能实现主要原理: 1: 在点击登录按钮的时候使用reponse.addCookie()方法向浏览器发送cookie: 2: 在前段拦截器中的request.getCookie()在接收到设 ...
- InnoDB: Error number 24 means ‘Too many open files’
一.问题的描述 备份程序 执行前滚的时候报错.(-apply-log) InnoDB: Errornumber 24 means 'Too many open files'. InnoDB: Some ...
- PyCharm在同一个包(package)下,如何把一个.py文件导入另外一个.py文件下
PyCharm在同一个包(package)下,如何把一个.py文件导入另外一个.py文件下 在同一个包下只需要用import 掉以后就可以找到模块所在的位置,但是如果不在同一个包下,在需要返回父级调用 ...