当前位置: 首页 > news >正文

网络流之最大流(dinic算法模板+模板题)

dinic算法:时间复杂度O(n^{2}*m), n 代表点的个数,m 代表边的个数。

const int N=1e5+5;
struct Edge{int to,w,next;
}edge[N*2];//双向边 
int head[N],d[N],cur[N];
int n,m,s,t,cnt=1;// 从 2 , 3 开始配对 
void add(int u,int v,int w){edge[++cnt]={v,w,head[u]};head[u]=cnt;
}
bool bfs(){// 对点分层,找增广路 memset(d,0,sizeof d);queue<int> q;q.push(s);d[s]=1;while(!q.empty()){int u=q.front();q.pop();for(int i=head[u];i;i=edge[i].next){int v=edge[i].to;if(d[v]==0 && edge[i].w){d[v]=d[u]+1;q.push(v);if(v==t) return true;}}}return false;
}
int dfs(int u,int flow){if(u==t) return flow;int sum=0;for(int i=cur[u];i;i=edge[i].next){cur[u]=i;// 当前弧优化 int v=edge[i].to;if(d[v]==d[u]+1 && edge[i].w){int f=dfs(v,min(flow,edge[i].w));edge[i].w-=f;edge[i^1].w+=f;// 更新残留网 sum+=f; // 累加 u 的流出流量 flow-=f;// 减少 u 的剩余流量 if(!flow) break;// 余量优化 }}if(!sum) d[u]=0;//残枝优化 return sum;
}
int dinic(){// 累加可行流 int ans=0;while(bfs()){memcpy(cur,head,sizeof head);//将 head 数组复制给 cur 数组 ans+=dfs(s,1e18);//初始值定为正无穷大 }return ans;
}

模板题:

思路:直接套用模板即可。(就比模板多了个加边)

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
const int N=1e5+5;
struct Edge{int to,w,next;
}edge[N*2];
int head[N],d[N],cur[N];
int n,m,s,t,cnt=1;
void add(int u,int v,int w){edge[++cnt]={v,w,head[u]};head[u]=cnt;
}
bool bfs(){memset(d,0,sizeof d);queue<int> q;q.push(s);d[s]=1;while(!q.empty()){int u=q.front();q.pop();for(int i=head[u];i;i=edge[i].next){int v=edge[i].to;if(d[v]==0 && edge[i].w){d[v]=d[u]+1;q.push(v);if(v==t) return true;}}}return false;
}
int dfs(int u,int flow){if(u==t) return flow;int sum=0;for(int i=cur[u];i;i=edge[i].next){cur[u]=i;int v=edge[i].to;if(d[v]==d[u]+1 && edge[i].w){int f=dfs(v,min(flow,edge[i].w));edge[i].w-=f;edge[i^1].w+=f;sum+=f;flow-=f;if(!flow) break;}}if(!sum) d[u]=0;return sum;
}
int dinic(){int ans=0;while(bfs()){memcpy(cur,head,sizeof head);ans+=dfs(s,1e18);}return ans;
}
signed main()
{IOScin >> n >> m >> s >> t;for(int i=1;i<=m;i++){int u,v,w;cin >> u >> v >> w;add(u,v,w);add(v,u,0);}cout << dinic() << endl;return 0;
}


http://www.mrgr.cn/news/29095.html

相关文章:

  • java程序打包及执行 jar命令及运行jar文件
  • WebRTC项目一对一视频
  • Matplotlib库中show()函数的用法
  • 【go从零单排】通道select、通道timeout、Non-Blocking Channel Operations非阻塞通道操作
  • 【数据库】深入解析慢 SQL 的识别与优化策略
  • 机器学习:XGBoost模型(升级版)——高效且强大的树形模型
  • 2024重生之回溯数据结构与算法系列学习【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
  • C++第六节课 - 拷贝构造函数
  • C++核心编程和桌面应用开发 第四天(构造/析构函数)
  • 【python设计模式2】创建型模式1
  • (185)时序收敛--->(35)时序收敛三五
  • C++ 科目二 [dynamic_cast]
  • 企业开发时,会使用sqlalchedmy来构建数据库 结构吗? 还是说直接写SQL 语句比较多?
  • makefile 的语法(7):函数 word wordlist words firstword lastword ;
  • 一种快速遍历二叉树的方法
  • 构建高效、精准的动物情绪分类模型:基于深度学习的技术实践与探索
  • 认知小文3《打破桎梏,编程与人生的基本法则》
  • 程序中类与对象的理解(面向对象思想)
  • kali——foremost的使用
  • 中秋佳节,月圆人团圆
  • 【数据结构篇】~链表算法题3(环形链表)
  • 【时时三省】linux应用层开发经验总结
  • 【计算机基础】关于存储的各种概念
  • 《沈阳体育学院学报》
  • 【每日一题】LeetCode 2332.坐上公交的最晚时间(数组、双指针、二分查找、排序)
  • 笔记:BLIP源码之(2)模型是如何定义的