首页 > 代码库 > 网络流模板
网络流模板
#include<bits/stdc++.h> using namespace std; #define M 10001 #define inf 100000 int ip=0,head[M],lv[M]; struct E{ int to,next,cap; }e[M]; void add(int x,int y,int z){ e[ip].to=y;e[ip].next=head[x];e[ip].cap=z;head[x]=ip++; e[ip].to=x;e[ip].next=head[y];e[ip].cap=0;head[y]=ip++; } int s,t; bool bfs(){ memset(lv,-1,sizeof(lv)); queue<int> q; q.push(s); lv[s]=0; while(!q.empty()){ int t=q.front(); q.pop(); for(int i=head[t];~i;i=e[i].next){ if(~lv[e[i].to]&&e[i].cap){ lv[e[i].to]=lv[t]+1; q.push(e[i].to); } } } return ~lv[t]; } int dfs(int u,int f){ if(u==t||f==0)return f; int ret=0; for(int i=head[u];~i;i=e[i].next){ if(lv[e[i].to]==lv[u]+1&&e[i].cap){ int w=dfs(e[i].to,min(f,e[i].cap)); e[i].cap-=w; e[i^1].cap+=w; f-=w; ret+=w; } } if(!ret)lv[u]=-1; return ret; } int dinic(){ int ans=0; while(bfs()){ ans+=dfs(s,inf); } return ans; } int main(){ return 0; }
网络流模板
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。