前言

网络流的练习为什么我又排在最后啊!!!

Solution

我们先来挖掘一个式子:
\[
ab+cd>ad+bc(a<c,b<d)
\]
这个的证明很显然对吧。
然后就考虑最优策略一定是让最大的边和最大的流量搞在一起。
但是发现最大的流量我们不能够确定啊。
所以就是二分答案?
每一次重新建一个图然后跑Dinic即可。
辣鸡聊天鬼才,毁我青春。

代码实现

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<string.h>
  4. #include<math.h>
  5. #include<algorithm>
  6. #include<queue>
  7. #include<set>
  8. #include<map>
  9. #include<iostream>
  10. using namespace std;
  11. #define ll long long
  12. #define re register
  13. #define file(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout)
  14. inline int gi(){
  15. int f=1,sum=0;char ch=getchar();
  16. while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}
  17. while(ch>='0' && ch<='9'){sum=(sum<<3)+(sum<<1)+ch-'0';ch=getchar();}
  18. return f*sum;
  19. }
  20. const int N=10010,M=100010;
  21. double Inf=1e9+10;
  22. int n,m,s,t,U[M],V[M];double Val[M],flow;
  23. class Graph{
  24. private:
  25. int front[N],nxt[M<<1],to[M<<1],cnt,dep[N],cur[N];
  26. double w[M<<1];
  27. bool bfs(){
  28. queue<int >Q;while(!Q.empty())Q.pop();
  29. memset(dep,0,sizeof(dep));
  30. Q.push(s);dep[s]=1;
  31. while(!Q.empty()){
  32. int u=Q.front();Q.pop();
  33. for(int i=front[u];i!=-1;i=nxt[i]){
  34. int v=to[i];
  35. if(!dep[v] && w[i]>=1e-10){
  36. dep[v]=dep[u]+1;Q.push(v);
  37. }
  38. }
  39. }
  40. return dep[t];
  41. }
  42. double dfs(int u,double Flow){
  43. if(u==t || !Flow)return Flow;
  44. for(int &i=cur[u];i!=-1;i=nxt[i]){
  45. int v=to[i];
  46. if(dep[v]==dep[u]+1 && w[i]>=1e-10){
  47. double di=dfs(v,min(Flow,w[i]));
  48. if(di>=1e-10){
  49. w[i]-=di;w[i^1]+=di;
  50. return di;
  51. }
  52. }
  53. }
  54. return 0;
  55. }
  56. public:
  57. void Add(int u,int v,double val){to[cnt]=v;nxt[cnt]=front[u];front[u]=cnt;w[cnt]=val;cnt++;}
  58. void init(){memset(front,-1,sizeof(front));cnt=0;}
  59. void Dinic(){
  60. while(bfs()){
  61. for(int i=1;i<=n;i++)cur[i]=front[i];
  62. double d=dfs(s,Inf);
  63. do{
  64. if(d<1e-10)break;
  65. flow+=d;
  66. }while(d=dfs(s,Inf));
  67. }
  68. }
  69. }MaxFlow;
  70. void build(double qaq){
  71. MaxFlow.init();
  72. for(int i=1;i<=m;i++){
  73. MaxFlow.Add(U[i],V[i],min(qaq,Val[i]));MaxFlow.Add(V[i],U[i],0);
  74. }
  75. }
  76. int main(){
  77. n=gi();m=gi();s=1;t=n;int p=gi();
  78. MaxFlow.init();
  79. for(int i=1;i<=m;i++){
  80. int u=gi(),v=gi(),val=gi();
  81. MaxFlow.Add(u,v,val);MaxFlow.Add(v,u,0);
  82. U[i]=u;V[i]=v;Val[i]=val;
  83. }
  84. MaxFlow.Dinic();
  85. printf("%.0lf\n",flow);double now=flow;
  86. double l=0,r=(double)flow+10,ans=0;
  87. while(r-l>=1e-10){
  88. double mid=(l+r)/2;
  89. build(mid);
  90. flow=0;
  91. MaxFlow.Dinic();
  92. if(now-flow<=1e-10)r=mid,ans=mid;
  93. else l=mid;
  94. }
  95. printf("%.4lf\n",ans*p);
  96. return 0;
  97. }

[Sdoi2013]费用流(最大流,二分答案)的更多相关文章

  1. 【Luogu】P3705新生舞会(费用流+分数规划+二分答案)

    题目链接 本来以为自己可以做出来,结果……打脸了 (貌似来wc立了好几个flag了,都没竖起来) 不过乱蒙能蒙出一个叫“分数规划”的东西的式子还是很开心的 观察$C=\frac{a_{1}+a_{2} ...

  2. poj2391 最大流+拆点+二分答案+Floyd

    Ombrophobic Bovines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 19553   Accepted: 4 ...

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

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

  4. bzoj 3597 [Scoi2014] 方伯伯运椰子 - 费用流 - 二分答案

    题目传送门 传送门 题目大意 给定一个费用流,每条边有一个初始流量$c_i$和单位流量费用$d_i$,增加一条边的1单位的流量需要花费$b_i$的代价而减少一条边的1单位的流量需要花费$a_i$的代价 ...

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

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

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

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

  7. Gym - 101908G 二分答案+最大流

    After the end of the truck drivers' strike, you and the rest of Nlogônia logistics specialists now h ...

  8. P3305 [SDOI2013]费用流

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

  9. luogu P3305 [SDOI2013]费用流

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

随机推荐

  1. DB2序列和主键自增长

    1.把主键定义为自动增长标识符类型 在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值.例如: create table customers(id int a ...

  2. java20(判断是否为会员)

    1.不确定数组是哪个类型是,将数据类型换成类名 2.记得将判断的参数传到方法中 3.用到类名的: 创建对象时 创建未知类型的数组时 4.创建的对象所用到的名字,体重,判断(boolean isvip ...

  3. Windows AD域管理软件

  4. 利用Delphi-cross-socket 库提升kbmmw 跨平台开发

    以前我写过了,通过httpsys 提升windows 下,delphi 多层应用.随着delphi 10.2 对linux 的支持,很多人也想在linux 下 发布kbmmw 服务器,但是官方仅通过i ...

  5. my.ini优化mysql数据库性能的十个参数(推荐)

    (1).max_connections:允许的同时客户的数量.增加该值增加 mysqld 要求的文件描述符的数量.这个数字应该增加,否则,你将经常看到 too many connections 错误. ...

  6. 2018.12.30 bzoj3028: 食物(生成函数)

    传送门 生成函数模板题. 我们直接把每种食物的生成函数列出来: 承德汉堡:1+x2+x4+...=11−x21+x^2+x^4+...=\frac 1{1-x^2}1+x2+x4+...=1−x21​ ...

  7. IPython:一种交互式计算和开发环境

    IPython基础 可以通过命令行启动IPython,执行任何Python语句,只需将其输入然后回车. Tab键自动完成 在Shell中输入表达式时,只要按下Tab键,当前命名空间中任何与已输入的字符 ...

  8. shell常见命令

    awk awk是个很好用的东西,大量使用在linux系统分析的结果展示处理上.并且可以使用管道, input | awk ''  | output 1.首先要知道形式 awk 'command' fi ...

  9. 第12章:MongoDB-CRUD操作--文档--查询--游标详解

    ①是什么游标 游标不是查询结果,可以理解为数据在遍历过程中的内部指针,其返回的是一个资源,或者说数据读取接口. 客户端通过对游标进行一些设置就能对查询结果进行有效地控制,如可以限制查询得到的结果数量. ...

  10. Java四种排序:冒泡,选择,插入,二分(折半插入)

    四种排序:冒泡,选择,插入,二分(折半插入) public class Test{ // public static void main(String[] args) { // Test t=new ...