BZOJ_1834_[ZJOI2010]network 网络扩容_费用流

题意:

给定一张有向图,每条边都有一个容量C和一个扩容费用W。这里扩容费用是指将容量扩大1所需的费用。
求: 
1、在不扩容的情况下,1到N的最大流; 
2、将1到N的最大流增加K所需的最小扩容费用。
 
分析:
第一问直接最大流。
第二问我们对于每条边,连一个容量不变,费用为0的表示不花钱能通过一些流量
再连一个容量无限,费用为扩容费用的边表示要想扩容必须花钱
再限制最大流为k,新建源点,源点向1连容量为k的边
跑最小费用最大流即可。
 
代码:
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <queue>
using namespace std;
#define N 2050
#define M 60050
#define inf 100000000
#define S (n+1)
#define T (n+2)
int head[N],to[M],nxt[M],flow[M],val[M],path[M],cnt=1;
int n,m,k,Q[N],l,r,dep[N],inq[N];
int xx[M],yy[M],cc[M],ww[M],dis[N];
inline void add1(int u,int v,int f)
{
to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;flow[cnt]=f;
}
inline void add2(int u,int v,int f,int c)
{
to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;flow[cnt]=f;val[cnt]=c;
}
bool bfs()
{
memset(dep,0,sizeof(dep));
l=r=0;
dep[1]=1;
Q[r++]=1;
int i;
while(l^r)
{
int x=Q[l++];if(l==n+1)l=0;
for(i=head[x];i;i=nxt[i])if(!dep[to[i]]&&flow[i])
{
dep[to[i]]=dep[x]+1;
if(to[i]==n)return 1;
Q[r++]=to[i];if(r==n+1)r=0;
}
}
return 0;
}
int dfs(int x,int mf)
{
if(x==n)return mf;
int nf=0;
int i;
for(i=head[x];i;i=nxt[i])if(dep[to[i]]==dep[x]+1&&flow[i])
{
int tmp=dfs(to[i],min(flow[i],mf-nf));
nf+=tmp;
flow[i]-=tmp;
flow[i^1]+=tmp;
if(nf==mf)break;
}
dep[x]=0;
return nf;
}
bool spfa()
{
memset(dis,0x3f,sizeof(dis));
memset(path,0,sizeof(path));
l=r=0;
int i;
Q[r++]=S;dis[S]=0;inq[S]=1;
while(l^r)
{
int x=Q[l++];if(l==n+4)l=0;inq[x]=0;
for(i=head[x];i;i=nxt[i])
{
if(flow[i]>0&&dis[to[i]]>dis[x]+val[i])
{
dis[to[i]]=dis[x]+val[i];
path[to[i]]=i^1;
if(!inq[to[i]])
{
inq[to[i]]=1;
Q[r++]=to[i];
if(r==n+4)r=0;
}
}
}
}
return dis[T]<inf;
}
void mcmf()
{
int mnc=0,mxf=0,i;
while(spfa())
{
int nf=1<<30;
for(i=T;i!=S;i=to[path[i]])
{
nf=min(nf,flow[path[i]^1]);
}
for(i=T;i!=S;i=to[path[i]])
{
flow[path[i]]+=nf;
flow[path[i]^1]-=nf;
mnc+=val[path[i]^1]*nf;
}
mxf+=nf;
}
printf("%d\n",mnc);
}
void dinic()
{
int ans=0,f;
while(bfs())
{
while(f=dfs(1,inf))
ans+=f;
}
k+=ans;
printf("%d ",ans);
}
int main()
{
scanf("%d%d%d",&n,&m,&k);
int i;
for(i=1;i<=m;i++)
{
scanf("%d%d%d%d",&xx[i],&yy[i],&cc[i],&ww[i]);
add1(xx[i],yy[i],cc[i]);
add1(yy[i],xx[i],0);
}
dinic();
cnt=1;
memset(head,0,sizeof(head));
add2(S,1,k,0);
add2(1,S,0,0);
add2(n,T,k,0);
add2(T,n,0,0);
for(i=1;i<=m;i++)
{
add2(xx[i],yy[i],cc[i],0);
add2(yy[i],xx[i],0,0);
add2(xx[i],yy[i],inf,ww[i]);
add2(yy[i],xx[i],0,-ww[i]);
}
mcmf();
}

  

BZOJ_1834_[ZJOI2010]network 网络扩容_费用流的更多相关文章

  1. BZOJ 1834 [ZJOI2010]network 网络扩容(费用流)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1834 [题目大意] 给定一张有向图,每条边都有一个容量C和一个扩容费用W. 这里扩容费 ...

  2. BZOJ1834 [ZJOI2010]network 网络扩容 【最大流,费用流】

    1834: [ZJOI2010]network 网络扩容 Time Limit: 3 Sec  Memory Limit: 64 MB Submit: 3394  Solved: 1774 [Subm ...

  3. 【BZOJ】1834: [ZJOI2010]network 网络扩容(最大流+费用流)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1834 我又思考人生了T_T,nd的数组开小了,一直wa,调了一个小时才发现啊!!!!!我一直以为我的 ...

  4. 2018.10.13 bzoj1834: [ZJOI2010]network 网络扩容(最大流+费用流)

    传送门 网络流水题啊. 第一问直接放心跑最大流(本来还以为有什么tricktricktrick). 第二问就直接把原来的边(u,v,c,w)(u,v,c,w)(u,v,c,w)变成(u,v,c,0)( ...

  5. bzoj 1834: [ZJOI2010]network 网络扩容【最大流+最小费用最大流】

    第一问直接跑最大流即可.建图的时候按照费用流建,费用为0. 对于第二问,在第一问dinic剩下的残量网络上建图,对原图的每条边(i,j),建(i,j,inf,cij),表示可以用c的花费增广这条路.然 ...

  6. BZOJ 1834: [ZJOI2010]network 网络扩容(最大流+最小费用最大流)

    第一问直接跑最大流.然后将所有边再加一次,费用为扩容费用,容量为k,再从一个超级源点连一条容量为k,费用为0的边到原源点,从原汇点连一条同样的边到超级汇点,然  后跑最小费用最大流就OK了. ---- ...

  7. bzoj 1834: [ZJOI2010]network 网络扩容 -- 最大流+费用流

    1834: [ZJOI2010]network 网络扩容 Time Limit: 3 Sec  Memory Limit: 64 MB Description 给定一张有向图,每条边都有一个容量C和一 ...

  8. [BZOJ1834][ZJOI2010]network 网络扩容 最大流+费用流

    1834: [ZJOI2010]network 网络扩容 Time Limit: 3 Sec  Memory Limit: 64 MB Submit: 3330  Solved: 1739 [Subm ...

  9. 【BZOJ1834】[ZJOI2010]network 网络扩容 最大流+最小费用流

    [BZOJ1834][ZJOI2010]network 网络扩容 Description 给定一张有向图,每条边都有一个容量C和一个扩容费用W.这里扩容费用是指将容量扩大1所需的费用.求: 1. 在不 ...

随机推荐

  1. Table对象代表一个HTML表格,在文档中<table>标签每出现一次,一个table对象就会被创建。

    1.对象集合 cells[] 返回包含表格中所有单元格的一个数组 rows[] 返回包含表格中所有行的一个数组 tBodies[] 返回包含表格中所有tbody的一个数组(主包含ty和td) 2.对象 ...

  2. angularjs学习笔记之一

    directive 通过AngularJS模块API中的.directive()方法,我们可以通过传入一个字符串和一个函数来 注册一个新指令.其中字符串是这个指令的名字,指令名应该是驼峰命名风格的,函 ...

  3. JavaScript遍历XML总结

    1:读取服务器端xml(注意不同浏览器版本的区别),使用XML可以增强系统的扩展性,只用修改XML就可以实现增加减少功能的目的. function loadXMLDoc1(dname){     if ...

  4. 手把手教你用Jenkins自动发布dotnet core程序

    Jenkins部分 首先,我们要有个Jenkins咯,下载链接:https://jenkins.io/download/ 我们安装官网教程安装好jenkins,安装教程略.... 嗯?不是说好手把手么 ...

  5. Nginx接收的host值会影响alias的规则匹配

    一般内网接收的HTTP请求都是内网唯一的网关传过来的,nginx的alias匹配会直接使用网关穿过的host值,而不是从URL解析出来的,从而导致的问题是,容器的alias相关Server_name规 ...

  6. Jersey VS Django-Rest

    在对Restful服务框架做对比前,主要先说说Restful设计的三大主要元素:以资源为核心的资源方法.资源状态.关系链接超媒体表述. 辅助的有内容协商.安全.版本化设计等. Jersey作为Java ...

  7. Fiddler抓包使用教程-Android应用抓包

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/74439165 本文出自[赵彦军的博客] Fiddler 也可以支持对手机应用进行 ...

  8. NSURLSession 所有的都在这里(一)

    这篇文章会有什么? 在这篇文章中把NSURLSession.h文件集体梳理一遍,把里面的每个属性.代理和方法都拿出来说说,通过这篇文章我相信对于NSURLSession这一块的东西会梳理的比较全面一点 ...

  9. flex调用JS报安全沙箱错误解决办法

    flex调用JS方法弹窗时一般会报安全沙箱错误,只要将被调用的JS方法设置延时就可解决. function openKqQuery(){ window.showModalDialog("pa ...

  10. Nginx负载均衡和反向代理

    1:反向代理 代理就是中介,那有反向代理就有正向代理,两者的区别是什么嘞? 正向代理隐藏真实客户端,服务端不知道实际发起请求的客户端.,proxy和client同属一个LAN,对server透明: 反 ...