[Sdoi2013]费用流(最大流,二分答案)
前言
网络流的练习为什么我又排在最后啊!!!
Solution
我们先来挖掘一个式子:
\[
ab+cd>ad+bc(a<c,b<d)
\]
这个的证明很显然对吧。
然后就考虑最优策略一定是让最大的边和最大的流量搞在一起。
但是发现最大的流量我们不能够确定啊。
所以就是二分答案?
每一次重新建一个图然后跑Dinic即可。
辣鸡聊天鬼才,毁我青春。
代码实现
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#include<iostream>
using namespace std;
#define ll long long
#define re register
#define file(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout)
inline int gi(){
int f=1,sum=0;char ch=getchar();
while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0' && ch<='9'){sum=(sum<<3)+(sum<<1)+ch-'0';ch=getchar();}
return f*sum;
}
const int N=10010,M=100010;
double Inf=1e9+10;
int n,m,s,t,U[M],V[M];double Val[M],flow;
class Graph{
private:
int front[N],nxt[M<<1],to[M<<1],cnt,dep[N],cur[N];
double w[M<<1];
bool bfs(){
queue<int >Q;while(!Q.empty())Q.pop();
memset(dep,0,sizeof(dep));
Q.push(s);dep[s]=1;
while(!Q.empty()){
int u=Q.front();Q.pop();
for(int i=front[u];i!=-1;i=nxt[i]){
int v=to[i];
if(!dep[v] && w[i]>=1e-10){
dep[v]=dep[u]+1;Q.push(v);
}
}
}
return dep[t];
}
double dfs(int u,double Flow){
if(u==t || !Flow)return Flow;
for(int &i=cur[u];i!=-1;i=nxt[i]){
int v=to[i];
if(dep[v]==dep[u]+1 && w[i]>=1e-10){
double di=dfs(v,min(Flow,w[i]));
if(di>=1e-10){
w[i]-=di;w[i^1]+=di;
return di;
}
}
}
return 0;
}
public:
void Add(int u,int v,double val){to[cnt]=v;nxt[cnt]=front[u];front[u]=cnt;w[cnt]=val;cnt++;}
void init(){memset(front,-1,sizeof(front));cnt=0;}
void Dinic(){
while(bfs()){
for(int i=1;i<=n;i++)cur[i]=front[i];
double d=dfs(s,Inf);
do{
if(d<1e-10)break;
flow+=d;
}while(d=dfs(s,Inf));
}
}
}MaxFlow;
void build(double qaq){
MaxFlow.init();
for(int i=1;i<=m;i++){
MaxFlow.Add(U[i],V[i],min(qaq,Val[i]));MaxFlow.Add(V[i],U[i],0);
}
}
int main(){
n=gi();m=gi();s=1;t=n;int p=gi();
MaxFlow.init();
for(int i=1;i<=m;i++){
int u=gi(),v=gi(),val=gi();
MaxFlow.Add(u,v,val);MaxFlow.Add(v,u,0);
U[i]=u;V[i]=v;Val[i]=val;
}
MaxFlow.Dinic();
printf("%.0lf\n",flow);double now=flow;
double l=0,r=(double)flow+10,ans=0;
while(r-l>=1e-10){
double mid=(l+r)/2;
build(mid);
flow=0;
MaxFlow.Dinic();
if(now-flow<=1e-10)r=mid,ans=mid;
else l=mid;
}
printf("%.4lf\n",ans*p);
return 0;
}
[Sdoi2013]费用流(最大流,二分答案)的更多相关文章
- 【Luogu】P3705新生舞会(费用流+分数规划+二分答案)
题目链接 本来以为自己可以做出来,结果……打脸了 (貌似来wc立了好几个flag了,都没竖起来) 不过乱蒙能蒙出一个叫“分数规划”的东西的式子还是很开心的 观察$C=\frac{a_{1}+a_{2} ...
- poj2391 最大流+拆点+二分答案+Floyd
Ombrophobic Bovines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 19553 Accepted: 4 ...
- BZOJ3130: [Sdoi2013]费用流[最大流 实数二分]
3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 960 Solved: 5 ...
- bzoj 3597 [Scoi2014] 方伯伯运椰子 - 费用流 - 二分答案
题目传送门 传送门 题目大意 给定一个费用流,每条边有一个初始流量$c_i$和单位流量费用$d_i$,增加一条边的1单位的流量需要花费$b_i$的代价而减少一条边的1单位的流量需要花费$a_i$的代价 ...
- BZOJ 3130: [Sdoi2013]费用流 网络流+二分
3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 1230 Solved: ...
- bzoj千题计划133:bzoj3130: [Sdoi2013]费用流
http://www.lydsy.com/JudgeOnline/problem.php?id=3130 第一问就是个最大流 第二问: Bob希望总费用尽量大,那肯定是把所有的花费加到流量最大的那一条 ...
- Gym - 101908G 二分答案+最大流
After the end of the truck drivers' strike, you and the rest of Nlogônia logistics specialists now h ...
- P3305 [SDOI2013]费用流
题目描述 Alice和Bob在图论课程上学习了最大流和最小费用最大流的相关知识. 最大流问题:给定一张有向图表示运输网络,一个源点S和一个汇点T,每条边都有最大流量. 一个合法的网络流方案必须满足: ...
- luogu P3305 [SDOI2013]费用流
题目链接 bz似乎挂了... luogu P3305 [SDOI2013]费用流 题解 dalao告诉我,这题 似乎很水.... 懂了题目大意就可以随便切了 问1,最大流 问2,二分最大边权求,che ...
随机推荐
- IOS初级:NSUserDefaults
NSUserDefaults(偏好设置),一个APP对应一个偏好设置 保存/新增数据 //存储数据 NSUserDefaults *defaults = [NSUserDefaults standar ...
- js之function
function* function* 这种声明方式(function关键字后跟一个星号)会定义一个生成器函数 (generator function),它返回一个 Generator 对象. 你 ...
- Go环境下,编译运行etcd与goreman集群管理(1)
Go环境下编译运行etcd与goreman管理 近几年了Go在比特币.区块链.云服务等相关重要领域贡献突出,作为IT行业的传承“活到老.学到光头”,保持学习心态. 周末放假,补充一二 主题:在Go环境 ...
- Web中的四大作用域对象
request:请求对象 类型:HttpServletRequest session:表示一次会话,可以处理一个用户多个页面之间的请求 application:标识web应用上下文,类型:Servle ...
- 使用promise判断是否登录
步骤: 1.创建并返回new Promise((success,error)=>{}),success和error分别是成功和失败后所执行的函数 2.判断是否含有cookie,如果含有cooki ...
- Android APP测试流程
一. Monkey测试(冒烟测试) 使用monkey测试工具进行如下操作: 1. APP的安装 2. APP随机操作测试(APP压力测试) 3. APP的卸载 二. 安装卸载测试 1. 使用测试真机进 ...
- ThinkPHP5 <= 5.0.22 远程代码执行高危漏洞
漏洞描述 由于ThinkPHP5框架对控制器名没有进行足够的安全检测,导致在没有开启强制路由的情况下,黑客构造特定的请求,可直接GetWebShell. 漏洞评级 严重 影响版本 ThinkPHP 5 ...
- 工作总结(二):Web Design
PHP框架:CakePHP 前端框架:Bootstrap Payment Data Transfer:https://developer.paypal.com/docs/classic/paypal- ...
- GDAL读写矢量文件——Python
在Python中使用OGR时,先要导入OGR库,如果需要对中文的支持,还需要导入GDAL库,具体代码如下.Python创建的shp结果如图1所示. 图1 Python创建矢量结果 #-*- codin ...
- python之深浅copy
深浅copy 1.赋值运算 a = [1, 2, 3] b = a a.append(666) print(b) #output:[1, 2, 3, 666] 对于赋值运算来说,a与b指向的是同一个内 ...