最大网络流算法
标签:lse http ons .com 数组 条件 pre std bsp
最大网络流,需要的准备是:BFS,EK算法
用pre数组记录前驱节点,用vis判断是否访问过
用g二维数组表示残余网络,用f二维数组表示实际流网络
下面这篇博客详细介绍了最大网络流:既然已经有了轮子,那我就不造了
https://www.cnblogs.com/zsboy/archive/2013/01/27/2878810.html
下面是我的代码
#include
#include
#include
#includeusing namespace std;
const int maxn=100;
const int INF=9999999;
int g[maxn][maxn];//残余网络,初始值为最大流量
int f[maxn][maxn];//实流网络,初始值都是零
int pre[maxn];//存储前驱节点
bool vis[maxn];//判断是否访问过
int n,m;
bool bfs(int s,int t)
{
memset(pre,-1,sizeof(pre));
memset(vis,false,sizeof(vis));
vis[s]=true;
queueint> que;
que.push(s);
while(!que.empty())
{
int now=que.front();
que.pop();
for(int i=1;i)
{
if(!vis[i]&&g[now][i]>0)//g[now][i]>0这个条件保证了bfs不会重复搜索
{
vis[i]=true;
pre[i]=now;
if(i==t) return true;
que.push(i);
}
}
}
return false;
}
int EK(int s,int t)
{
int v,w,d,maxflow;
maxflow=0;
while(bfs(s,t))
{
d=INF;
v=t;
while(v!=s)
{
w=pre[v];
if(d>g[w][v]) d=g[w][v];
v=w;
}
maxflow+=d;
v=t;
while(v!=s)
{
w=pre[v];
g[w][v]-=d;
g[v][w]+=d;
if(f[v][w]>0)
f[v][w]-=d;
else
f[w][w]+=d;
v=w;
}
}
return maxflow;
}
int main()
{
int u,v,w;
cin>>n>>m;
memset(g,0,sizeof(g));
memset(f,0,sizeof(f));
for(int i=1;i)
{
cin>>u>>v>>w;
g[u][v]+=w;
}
cout1,n)endl;
return 0;
}
最大网络流算法
标签:lse http ons .com 数组 条件 pre std bsp
原文地址:https://www.cnblogs.com/acmblog/p/9648998.html
文章来自:
搜素材网的
编程语言模块,转载请注明文章出处。
文章标题:
最大网络流算法
文章链接:http://soscw.com/index.php/essay/98922.html
评论