随笔-68  评论-10  文章-0  trackbacks-0
/*
   EdmondsKarp算法,O(m^2n)
*/

#include
<iostream>
#include
<queue>
using namespace std;
const int maxn=205;
const int inf=0x7fffffff;

int r[maxn][maxn]; //残留网络,初始化为原图
bool visit[maxn];
int pre[maxn];
int m,n;

bool bfs(int s,int t)  //寻找一条从s到t的增广路,若找到返回true
{
    
int p;
    queue
<int > q;
    memset(pre,
-1,sizeof(pre));
    memset(visit,
false,sizeof(visit));

    pre[s]
=s;
    visit[s]
=true;
    q.push(s);
    
while(!q.empty())
    
{
        p
=q.front();
        q.pop();
        
for(int i=1;i<=n;i++)
        
{
            
if(r[p][i]>0&&!visit[i])
            
{
                pre[i]
=p;
                visit[i]
=true;
                
if(i==t) return true;
                q.push(i);
            }

        }

    }

    
return false;
}


int EdmondsKarp(int s,int t)
{
   
int flow=0,d,i;
   
while(bfs(s,t))
   
{
       d
=inf;
       
for(i=t;i!=s;i=pre[i])
           d
=d<r[pre[i]][i]? d:r[pre[i]][i];
       
for(i=t;i!=s;i=pre[i])
       
{
           r[pre[i]][i]
-=d;
           r[i][pre[i]]
+=d;
       }

       flow
+=d;
   }

   
return flow;
}



int main()
{
    
while(scanf("%d%d",&m,&n)!=EOF)
    
{
        
int u,v,w;
        memset(r,
0,sizeof(r));///
        for(int i=0;i<m;i++)
        
{
            scanf(
"%d%d%d",&u,&v,&w);
            r[u][v]
+=w;
        }

        printf(
"%d\n",EdmondsKarp(1,n));
    }

    
return 0;
}
posted on 2011-05-10 13:10 wuxu 阅读(296) 评论(0)  编辑 收藏 引用 所属分类: 图论

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理