1 #include<bits/stdc++.h>
2 #define int long long
3 using namespace std;
4 const int maxn=5005;
5 const int inf=0x3f3f3f3f;
6 int tot,n,m,s,t,x,y,z,d[maxn];
7 int adj[maxn],nex[maxn<<1],to[maxn<<1],w[maxn<<1],flow[maxn<<1];
8 void add(int x,int y,int z){
9 nex[tot]=adj[x];
10 adj[x]=tot;
11 to[tot]=y;
12 w[tot]=z;
13 flow[tot++]=0;
14 }
15 bool bfs(){
16 memset(d,0,sizeof(d));
17 queue<int> q;
18 d[s]=1;
19 q.push(s);
20 while(!q.empty()){
21 int u=q.front();
22 q.pop();
23 for(int i=adj[u];~i;i=nex[i]){
24 int v=to[i];
25 if(!d[v]&&w[i]>flow[i]){
26 d[v]=d[u]+1;
27 q.push(v);
28 if(v==t) return 1;
29 }
30 }
31 }
32 return 0;
33 }
34 int dfs(int u,int fw){
35 if(u==t) return fw;
36 int rest=fw;
37 for(int i=adj[u];~i&&rest;i=nex[i]){
38 int v=to[i];
39 if(d[v]==d[u]+1&&w[i]>flow[i]){
40 int k=dfs(v,min(rest,w[i]-flow[i]));
41 if(!k) d[v]=0;
42 flow[i]+=k;
43 flow[i^1]-=k;
44 rest-=k;
45 }
46 }
47 return fw-rest;
48 }
49 int dinic(){
50 int maxflow=0;
51 while(bfs()){
52 //for(int i=1;i<=n;i++)
53 maxflow+=dfs(s,inf);
54 }
55 return maxflow;
56 }
57 signed main()
58 {
59 cin>>n>>m>>s>>t;
60 memset(adj,-1,sizeof(adj));
61 for(int i=1;i<=m;i++){
62 cin>>x>>y>>z;
63 add(x,y,z);add(y,x,0);
64 }
65 cout<<dinic();
66 return 0;
67 }

注意几个细节:adj初始化为-1,tot下标从0开始;~i

加上当前弧优化

#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxn=5005;
const int inf=0x3f3f3f3f;
int tot,n,m,s,t,x,y,z,d[maxn],now[maxn];
int adj[maxn],nex[maxn<<1],to[maxn<<1],w[maxn<<1],flow[maxn<<1];
void add(int x,int y,int z){
nex[tot]=adj[x];
adj[x]=tot;
to[tot]=y;
w[tot]=z;
flow[tot++]=0;
}
bool bfs(){
memset(d,0,sizeof(d));
queue<int> q;
d[s]=1;
q.push(s);
for(int i=1;i<=n;i++)
now[i]=adj[i];
while(!q.empty()){
int u=q.front();
q.pop();
for(int i=adj[u];~i;i=nex[i]){
int v=to[i];
if(!d[v]&&w[i]>flow[i]){
d[v]=d[u]+1;
q.push(v);
if(v==t) return 1;
}
}
}
return 0;
}
int dfs(int u,int fw){
if(u==t) return fw;
int rest=fw;
for(int i=now[u];~i&&rest;i=nex[i]){
int v=to[i];
if(d[v]==d[u]+1&&w[i]>flow[i]){
int k=dfs(v,min(rest,w[i]-flow[i]));
if(!k) d[v]=0;
flow[i]+=k;
flow[i^1]-=k;
rest-=k;
}
}
return fw-rest;
}
int dinic(){
int maxflow=0;
while(bfs()){
//for(int i=1;i<=n;i++)
maxflow+=dfs(s,inf);
}
return maxflow;
}
signed main()
{
cin>>n>>m>>s>>t;
memset(adj,-1,sizeof(adj));
for(int i=1;i<=m;i++){
cin>>x>>y>>z;
add(x,y,z);add(y,x,0);
}
cout<<dinic();
return 0;
}

洛谷P3376 (最大流模板)的更多相关文章

  1. 洛谷 P3376 【【模板】网络最大流】

    题目描述 如题,给出一个网络图,以及其源点和汇点,求出其网络最大流. 输入 第一行包含四个正整数N.M.S.T,分别表示点的个数.有向边的个数.源点序号.汇点序号. 接下来M行每行包含三个正整数ui. ...

  2. 题解 洛谷 P3376 【【模板】网络最大流】

    本人很弱,只会Dinic.EK与Ford-Fulkerson...(正在学习ISAP...) 这里讲Dinic... Dinic:与Ford-Fulkerson和的思路相似(话说好像最大流求解都差不多 ...

  3. [洛谷P3376题解]网络流(最大流)的实现算法讲解与代码

    [洛谷P3376题解]网络流(最大流)的实现算法讲解与代码 更坏的阅读体验 定义 对于给定的一个网络,有向图中每个的边权表示可以通过的最大流量.假设出发点S水流无限大,求水流到终点T后的最大流量. 起 ...

  4. 【洛谷P3369】【模板】普通平衡树题解

    [洛谷P3369][模板]普通平衡树题解 题目链接 题意: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3 ...

  5. 洛谷P3376【模板】网络最大流 ISAP

    这篇博客写得非常好呀. 传送门 于是我是DCOI这一届第一个网络流写ISAP的人了,之后不用再被YKK她们嘲笑我用Dinic了!就是这样! 感觉ISAP是会比Dinic快,只分一次层,然后不能增广了再 ...

  6. bzoj 5120 无限之环 & 洛谷 P4003 —— 费用流(多路增广SPFA)

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5120 https://www.luogu.org/problemnew/show/P4003 ...

  7. 【洛谷4721】【模板】分治FFT(CDQ分治_NTT)

    题目: 洛谷 4721 分析: 我觉得这个 "分治 FFT " 不能算一种特殊的 FFT ,只是 CDQ 分治里套了个用 FFT (或 NTT)计算的过程,二者是并列关系而不是偏正 ...

  8. 草地排水 洛谷P2740 最大流 入门题目

    草地排水 洛谷P2740 最大流入门题目 题意 在农夫约翰的农场上,每逢下雨,贝茜最喜欢的三叶草地就积聚了一潭水.这意味着草地被水淹没了,并且小草要继续生长还要花相当长一段时间.因此,农夫约翰修建了一 ...

  9. 【洛谷3865】 【模板】ST表(猫树)

    传送门 洛谷 Solution 实测跑的比ST表快!!! 这个东西也是\(O(1)\)的,不会可以看我上一篇Blog 代码实现 代码戳这里

  10. 【最大流ISAP】洛谷P3376模板题

    题目描述 如题,给出一个网络图,以及其源点和汇点,求出其网络最大流. 输入输出格式 输入格式: 第一行包含四个正整数N.M.S.T,分别表示点的个数.有向边的个数.源点序号.汇点序号. 接下来M行每行 ...

随机推荐

  1. C# 实例解释面向对象编程中的依赖反转原则

    在面向对象编程中,SOLID 是五个设计原则的首字母缩写,旨在使软件设计更易于理解.灵活和可维护.这些原则是由美国软件工程师和讲师罗伯特·C·马丁(Robert Cecil Martin)提出的许多原 ...

  2. raspberrypi系统在加入k8s作为node节点时遇到的问题

    新买的树莓派4b到货后就迫不及待的烧录上raspberrypi系统,将新派加入我的k8s集群,期间遇到了点小挫折,好歹也一个一个解决了: 一.kubelet版本不对导致无法加入k8s集群 在执行kub ...

  3. go将青龙面板里面的脚本文件都下载到本地

    纯粹练手用的,大家轻喷 青龙面板的脚本文件可以下载到本地,这样的话自己可以研究一下对应的脚本文件,能学到更多的知识,原理其实很简单,F12一下就知道了,青龙面板使用Request Headers里面放 ...

  4. python type 与 metaclass理解

    简介 众所周知,type在一般情况下,我们都会去获取一个对象的类型,然后进行类型的比较:除此之外,type还有一个不为人知的作用:动态的创建类.在了解这个之前,首先了解以下type和isinstanc ...

  5. vscode problem

    1.Inconsistent use of tabs and spaces in indentation 原因:tab和空格键不能同时使用 vs code按住ctrl + p,输入以下内容 >c ...

  6. iNeuOS工业互联网操作系统,设备运维业务和“低代码”表单开发工具

    目       录 1.      概述... 2 2.      设备运维业务... 3 3.      "低代码"表单开发工具... 6 1.   概述 iNeuOS工业互联网 ...

  7. 从零开始Blazor Server(8)--增加菜单以及调整位置

    这篇干啥 这篇文章主要是把前面的一些东西稍微调整一下,使其更适合后面的内容. 主要是两个事,一个是把原来的PermissionEntity直接变成MenuEntity,直接让最后一级是菜单,这样后面就 ...

  8. 故障案例 | lsof是怎么"影响"MySQL计算打开文件句柄数的

    欢迎来到 GreatSQL社区分享的MySQL技术文章,如有疑问或想学习的内容,可以在下方评论区留言,看到后会进行解答 lsof中附加不同参数产生的结果也不同,小心"踩坑". 1. ...

  9. 中国联通改造 Apache DolphinScheduler 资源中心,实现计费环境跨集群调用与数据脚本一站式访问

    截止2022年,中国联通用户规模达到4.6亿,占据了全中国人口的30%,随着5G的推广普及,运营商IT系统普遍面临着海量用户.海量话单.多样化业务.组网模式等一系列变革的冲击. 当前,联通每天处理话单 ...

  10. Apache 首次亚洲在线峰会: Workflow & 数据治理专场

    背景 大数据发展到今天已有 10 年时间,早已渗透到各个行业,数据需 求越来越多,这使得大数据 业务间的依赖关系也越来越复杂,另外也相信做数据的伙伴肯定对如何治理数据也是痛苦之至,再加上现今云原生时代 ...