BZOJ 1834--网络扩容(最大流&费用流)
1834: [ZJOI2010]network 网络扩容
Time Limit: 3 Sec Memory Limit: 64 MB
Submit: 3351 Solved: 1750
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2 5 8
2 5 9 9
5 1 6 2
5 1 1 8
1 2 8 7
2 5 4 9
1 2 1 1
1 4 2 1
Sample Output
30%的数据中,N<=100
100%的数据中,N<=1000,M<=5000,K<=10
题目链接:
http://www.lydsy.com/JudgeOnline/problem.php?id=1834
Solution
值得一做的好题。。。
第一问是赤果果的最大流。。。上模板就好。。。
然后问扩流的最小费用。。。发现可以直接利用之前跑完最大流剩下的残余网络。
在每一条边上额外加一条容量无限大的边,但是这样不能控制流的大小,所以要额外添加一个汇点S。
从S向原起点连一条容量为k的边,再跑一遍费用流,就是第二问的答案。。。
代码
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<iostream>
#define N 1010
#define inf 2000000000
using namespace std;
inline int Read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int n,m,k,ans=0,cnt=1,S,T;
int hed[N],dis[N],l[N],q[200000];
bool vis[N];
struct edge{
int l,r,nxt,v,c,t;
}e[50000];
void insert(int u,int v,int w,int c){
cnt++;e[cnt].l=u;e[cnt].r=v;e[cnt].nxt=hed[u];hed[u]=cnt;e[cnt].v=w;e[cnt].c=0;e[cnt].t=c;
cnt++;e[cnt].l=v;e[cnt].r=u;e[cnt].nxt=hed[v];hed[v]=cnt;e[cnt].v=0;e[cnt].c=0;e[cnt].t=-c;
}
bool BFS(){
int head=0,tail=1,now;
memset(dis,-1,sizeof(dis));
dis[S]=1;q[1]=S;
while(head!=tail){
head++;
now=q[head];
for(int i=hed[now];i;i=e[i].nxt)
if(e[i].v && dis[e[i].r]==-1){
dis[e[i].r]=dis[now]+1;
q[++tail]=e[i].r;
}
}
return dis[T]!=-1;
}
int DFS(int x,int F){
if(x==T)return F;
int w,used=0;
for(int i=hed[x];i;i=e[i].nxt)
if(dis[e[i].r]==dis[x]+1){
w=F-used;
if(w>e[i].v)w=e[i].v;
w=DFS(e[i].r,w);
e[i].v-=w;
e[i^1].v+=w;
used+=w;
if(used==F)return F;
}
if(!used)dis[x]=-1;
return used;
}
void dinic(){
while( BFS() )
ans+=DFS(S,inf);
}
void ins(int u,int v,int w,int c){
cnt++;e[cnt].l=u;e[cnt].r=v;e[cnt].v=w;e[cnt].nxt=hed[u];hed[u]=cnt;e[cnt].c=c;
cnt++;e[cnt].l=v;e[cnt].r=u;e[cnt].v=0;e[cnt].nxt=hed[v];hed[v]=cnt;e[cnt].c=-c;
}
bool spfa(){
int head=0,tail=1,now;
for(int i=0;i<=n;i++)dis[i]=inf;
q[1]=S;dis[S]=0;vis[S]=1;
while(head!=tail){
head++;
now=q[head];
for(int i=hed[now];i;i=e[i].nxt)
if(e[i].v>0 && dis[now]+e[i].c<dis[e[i].r]){
dis[e[i].r]=dis[now]+e[i].c;
l[e[i].r]=i;
if(!vis[e[i].r]){
tail++;
q[tail]=e[i].r;
vis[e[i].r]=1;
}
}
vis[now]=0;
}
return dis[T]!=inf;
}
int mincf(){
int now,used=inf;
now=l[T];
while(now){
if(used>e[now].v)used=e[now].v;
now=l[e[now].l];
}
now=l[T];
while(now){
e[now].v-=used;
e[now^1].v+=used;
ans+=used*e[now].c;
now=l[e[now].l];
}
}
void Cost_Flow(){
while( spfa() )
ans+=mincf();
}
int main(){
int u,v,w,c;
n=Read();m=Read();k=Read();
S=1;T=n;
for(int i=1;i<=m;i++){
u=Read();v=Read();w=Read();c=Read();
insert(u,v,w,c);
}
dinic();
printf("%d ",ans);
ans=0;
int tot=cnt;
for(int i=2;i<=tot;i+=2)
ins(e[i].l,e[i].r,inf,e[i].t);
S=0;
ins(0,1,k,0);
Cost_Flow();
printf("%d\n",ans);
return 0;
}
This passage is made by Iscream-2001.
BZOJ 1834--网络扩容(最大流&费用流)的更多相关文章
- BZOJ 1834 网络扩容(最大流+费用流)
对于第一问,直接求最大流. 对于第二问,建源点s和汇点t,s连1容量为INF,费用为0的边,n连t容量为最大流+k,费用为0的边.这样就把最大流限制为最多增加k了. 限制需要求扩充的最小费用,原图的边 ...
- BZOJ 1834 网络扩容 最大流+最小费用流
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1834 题目大意: 给定一张有向图,每条边都有一个容量C和一个扩容费用W.这里扩容费用是 ...
- BZOJ 1834网络扩容题解
一道不算太难的题目 但是真的很恶心 显然,对于第一问,我们直接无脑打模板就好了 第二问也不是很难,我们将每条边再连一条容量为inf,费用为w的边 但是流量只要小于第一问的答案加k就行了 所以我们增加一 ...
- BZOJ 1834: [ZJOI2010]network 网络扩容(网络流+费用流)
一看就知道是模板题= = ,不说什么了= = PS:回去搞期末了,暑假再来刷题了 CODE: #include<cstdio> #include<iostream> #incl ...
- 洛谷P2604 网络扩容 拆点+费用流
原题链接 这题貌似比较水吧,最简单的拆点,直接上代码了. #include <bits/stdc++.h> using namespace std; #define N 1000 #def ...
- BZOJ 3876 支线剧情 | 有下界费用流
BZOJ 3876 支线剧情 | 有下界费用流 题意 这题题面搞得我看了半天没看懂--是这样的,原题中的"剧情"指的是边,"剧情点"指的才是点. 题面翻译过来大 ...
- 从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流)
从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流) 题面 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难题:为即将启动的奥运 ...
- 【BZOJ】1834: [ZJOI2010]network 网络扩容(最大流+费用流)
http://www.lydsy.com/JudgeOnline/problem.php?id=1834 我又思考人生了T_T,nd的数组开小了,一直wa,调了一个小时才发现啊!!!!!我一直以为我的 ...
- bzoj 1834: [ZJOI2010]network 网络扩容 -- 最大流+费用流
1834: [ZJOI2010]network 网络扩容 Time Limit: 3 Sec Memory Limit: 64 MB Description 给定一张有向图,每条边都有一个容量C和一 ...
随机推荐
- tomcat 域名直接访问默认工程,而不添加项目路径
<Engine name="Catalina" defaultHost="xx.xx.xx.xx"> <!--For clustering, ...
- LUA表的引用理解
--lua中引用类型都是分配在堆上的 --因此,我们在使用LUA的table时,可尽可能的使用表的引用,而不需要拷贝表里的元素 --比如,通过RPC协议传来一个表A,我们想要缓存这个表,只需要保存该表 ...
- 迷你MVVM框架 avalonjs 学习教程8、属性操作
属性操作是DOM操作很大的一块,它包括类名操作,表单元素的value属性操作,元素固有属性的管理,元素自定义属性的管理,某些元素的一些布尔属性的操作.大多数情况下,元素属性的值是字符串类型,我们称之为 ...
- django中文件下载(HttpResponse)
最近一个用django开发的web项目要进行数据的导入导出,所以有必要了解下. django中主要用HttpResponse将请求结果返回给浏览器,所以文件的下载也是通过改对象进行处理的,具体的一个列 ...
- Layer Comps
[What is Layer Comps] Designers often create multiple compositions(comps) of a page layout to show c ...
- python报OperationalError: (1366, "Incorrect string value..."的问题解决
一.环境及问题描述 1. 环境 操作系统:win10,64bit. python版本:2.7.15 mysql版本:5.7.23 2. 问题描述 使用python从某个数据文件读取数据,处理后,用My ...
- 从上往下打印二叉树(java)
import java.util.ArrayList; import java.util.*; /** public class TreeNode { int val = 0; TreeNode le ...
- ubuntu 卡在登陆界面无法进入桌面,但是可以进入命令行界面
ubuntu 卡在登陆界面无法进入桌面,但是可以进入命令行界面(初步断定是Xwindows界面软件出问题了,所以重装即可!)Solve: 1.Ctrl+Alt+F1进入命令行界面,root账户登陆2. ...
- C程序设计语言(2)文摘
第一章 导言 1.1 入门 1.2 变量与算术表达式 1.3 for语句 1.4 符号常量 1.5 字符输入输出 #include "stdafx.h" main(int argc ...
- Web数据挖掘综述