[讲解]网络流最大流dinic算法
网络流最大流算法dinic
ps:本文章不适合萌新,我写这个主要是为了复习一些细节,概念介绍比较模糊,建议多刷题去理解
例题:codevs草地排水,方格取数
【抒情一下】
虽然老师说这个多半不考,但是学了没坏处,所以我就把这算法学了(准确说是补起了QAQ)
以前一直觉得dinic的代码好长好难啊,然后就知难而退
最近学了很多和看了很多以后,咱们就学会了知男♂而上了,所以我果断的回来上dinic了
【dinic】
Dinic算法是用来做最大流一类题的,代码有一丢丢的长,但其实说白了就是一个bfs+dfs就没了,所以没必要有啥心理负担

我们先来画一个图,我们需要从1点流到n点
首先看这个图,每条边上标的是这条边的容量
Dinic的想法就是对当前图去找一条还能够从s通往t的可行路
然后可行路可以由图中的边组成,也可以用图中的边的逆向边组成
至于为什么要建立逆向边和逆向边的含义,我们重新画一张图

我假设这张图的目前的流量为
E(s,2)=0,E(s,1)=4,E(1,2)=2,E(2,t)=2,E(1,t)=2;
然后我们建立逆向边或者说是反向弧,就是沿着箭头的反方向建边,反向边的容量为正向边的流量(不是容量)
所以当前反向边的容量为
E(2,s)=0,E(1,s)=4,E(2,1)=2,E(t,2)=2,E(t,1)=2;
然后为什么要建立这些边,我们先看图,当前的图肯定不是最优的,这时候就要找增广路
增广路简单一点理解就是还有一条从s到t的路
然后我们发现边s,1是满的,所以找到可以流的边s,2的流量是0,然后到2点发现2,1边的容量是2(因为E(1,2)=2,所以反向此时的容量为2),最后发现1,t边容量4流量2,于是找到一条增广路
S->2->1->t,这条增广路可以扩大2的流量,所以最大流+2,为6
至于程序也很简单,首先是建图,建完图以后一个while循环(用bfs判断),bfs的过程是找还有没有增广路,然后在循环内dfs,dfs是找这条增广路的可以扩大的最大流量
至于在dfs判断是否是我们找出的合法路径,可以在bfs是对路径加深度,如果容量大于流量并且不是同一深度,那么dfs就可以继续搜索下去
然后我给一个dinic的模版,模板题就用草地排水了
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<queue>
#include<cmath>
#include<cstdlib>
#include<stack>
#define maxn 505
using namespace std; queue<int>q;
int c[maxn],head[maxn],f[maxn],n,m,dep[maxn],ans;
struct edge{
int u,v,w,nxt,flow;
}e[maxn]; int read(){
int xx=,ff=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')ff=-;ch=getchar();}
while(ch>=''&&ch<=''){xx=xx*+ch-'';ch=getchar();}
return xx*ff;
} int tot=;
void adde(int u,int v,int w){
e[++tot].u=u;
c[tot]=w;
e[tot].v=v;e[tot].w=w;
e[tot].nxt=head[u];
head[u]=tot;
} int bfs(){
q.push();
memset(dep,-,sizeof(dep));
dep[]=;
while(!q.empty()){
int u=q.front();q.pop();
for(int i=head[u];i!=-;i=e[i].nxt){
int v=e[i].v;
if(dep[v]==-&&c[i]-f[i]){
dep[v]=dep[u]+;
q.push(v);
}
}
}
if(dep[n]==-)return ;
else return ;
} int dfs(int u,int lim){
if(u==n){ans+=lim;return lim;}
int t;
for(int i=head[u];i!=-;i=e[i].nxt ){
int v=e[i].v;
if(c[i]-f[i]&&dep[u]+==dep[v]&&(t=dfs(v,min(lim,c[i]-f[i])))){
f[i]+=t;f[i^]-=t;return t;
}
}
return ;
} int main(){
memset(head,-,sizeof(head));
m=read();n=read();
for(int i=;i<=m;i++){
int u,v,w;
u=read();v=read();w=read();
adde(u,v,w);adde(v,u,);
}
while(bfs()){
dfs(,0x3f3f3f);
}
printf("%d",ans);
}
【总结】
网络流的难点在于建图,这个另类的建图可以参加一下方格取数,拓宽一下视野
[讲解]网络流最大流dinic算法的更多相关文章
- 网络流最大流——dinic算法
前言 网络流问题是一个很深奥的问题,对应也有许多很优秀的算法.但是本文只会讲述dinic算法 最近写了好多网络流的题目,想想看还是写一篇来总结一下网络流和dinic算法以免以后自己忘了... 网络流问 ...
- Power Network(网络流最大流 & dinic算法 + 优化)
Power Network Time Limit: 2000MS Memory Limit: 32768K Total Submissions: 24019 Accepted: 12540 D ...
- 网络流——最大流Dinic算法
前言 突然发现到了新的一年什么东西好像就都不会了凉凉 算法步骤 建残量网络图 在残量网络图上跑增广路 重复1直到没有增广路(注意一个残量网络图要尽量把价值都用完,不然会浪费建图的时间) 代码实现 #i ...
- 网络流之最大流Dinic算法模版
/* 网络流之最大流Dinic算法模版 */ #include <cstring> #include <cstdio> #include <queue> using ...
- 网络流(最大流-Dinic算法)
摘自https://www.cnblogs.com/SYCstudio/p/7260613.html 网络流定义 在图论中,网络流(Network flow)是指在一个每条边都有容量(Capacity ...
- 学习笔记 --- 最大流Dinic算法
为与机房各位神犇同步,学习下网络流,百度一下发现竟然那么多做法,最后在两种算法中抉择,分别是Dinic和ISAP算法,问过 CA爷后得知其实效率上无异,所以决定跟随Charge的步伐学习Dinic,所 ...
- hdu-3572 Task Schedule---最大流判断满流+dinic算法
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3572 题目大意: 给N个任务,M台机器.每个任务有最早才能开始做的时间S,deadline E,和持 ...
- (通俗易懂小白入门)网络流最大流——EK算法
网络流 网络流是模仿水流解决生活中类似问题的一种方法策略,来看这么一个问题,有一个自来水厂S,它要向目标T提供水量,从S出发有不确定数量和方向的水管,它可能直接到达T或者经过更多的节点的中转,目前确定 ...
- 最大流——Dinic算法
前面花了很长时间弄明白了压入-重标记的各种方法,结果号称是O(V3)的算法测demo的时候居然TLE了一个点,看了题解发现所有人都是用Dinic算法写的,但它的复杂度O(V2E)明显高于前者,具体是怎 ...
随机推荐
- 原生js实现在表格用鼠标框选并有反选功能
今天应同学要求,需要写一个像Excel那样框选高亮,并且实现框选区域实现反选功能.要我用原生js写,由于没什么经验翻阅了很多资料,第一次写文章希望各位指出不足!! 上来先建表 <div clas ...
- day06可变与不可变类型,if判断,运算符
1:可变不可变类型 2.什么是条件?什么可以当做条件?为何要要用条件? 显式布尔值:True.False 隐式布尔值:所有数据类型,其中0.None.空为假 3:逻辑运算符:用来 # not. and ...
- 群ping
找出单位内所有电脑手机 通常情况下,ping只能ping一个IP地址.一个网络值班只有255台电脑,除非是大的网络断,把子网掩码改了,可以扩充更多电脑.如: 如果我们要一次性检查内网所有机器,则可以输 ...
- div隐藏滚动条,仍可滚动
<!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...
- PG归并排序算法详解
前言 归并排序算法是连接算法中比较复杂的算法,相比嵌套循环与Hash匹配而言.本节会通过实例来说明该算法在PG中的具体实现. 在PG中,通过状态机来实现--归并-连接.当然这里的完整流程是排序--归并 ...
- 【JDK】JDK源码分析-HashMap(2)
前文「JDK源码分析-HashMap(1)」分析了 HashMap 的内部结构和主要方法的实现原理.但是,面试中通常还会问到很多其他的问题,本文简要分析下常见的一些问题. 这里再贴一下 HashMap ...
- 吐血干货,直播首屏耗时400ms以下的优化实践
导读: 直播行业的竞争越来越激烈,进过18年这波洗牌后,已经度过了蛮荒暴力期,剩下的都是在不断追求体验.最近在帮做直播优化首开,通过多种方案并行,把首开降到500ms以下,希望能对大家有借鉴. 背景: ...
- js 运动的应用 新浪微博
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- (转)协议森林12 天下为公 (TCP堵塞控制)
协议森林12 天下为公 (TCP堵塞控制) 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在TCP协议中,我们使用连接记录TCP ...
- 2020年IOS超级签最新实现原理详解
相信2019年最火的应该就是这个东西了,我也是摸着石头过河,勉强混进了这个行业! 超级签这个东西吧,说白了就是用个人账号分发应用,大致分成以下几个步骤吧 一.使用配置文件获取UDID 苹果公司允许开发 ...