Ford Fulkerson 算法


#include <iostream>
#include <cstring>
#include <vector>
using namespace std;

#define MAX_V 100
#define INF 1 << 30

struct Edge{

    int to;
    int cap;
    int rec;

    Edge( int to, int cap, int rec ){
        this->to  = to;
        this->cap = cap;
        this->rec = rec;
    }

};


vector< Edge > G[MAX_V];
bool visited[MAX_V];


void add_edge( int from, int to, int cap ){

    Edge e  = Edge( to, cap, G[to].size() );
    Edge re = Edge( from, cap, G[from].size() );

    G[from].push_back( e );
    G[to].push_back( re );

}


int find_flow( int from, int des, int flow ){

    if( from == des )
        return flow;

    visited[from] = true;

    for( int i = 0; i < G[from].size(); ++i ){

        Edge& e = G[from][i];

        if( !visited[e.to] && e.cap > 0 ){

            int f = find_flow( e.to, des, min( flow, e.cap ) );

            if( f > 0 ){

                e.cap -= f;
                G[e.to][e.rec].cap += f;

                return f;
            }
        }
    }

    return 0;
}


int max_flow( int src, int des ){

    int flow = 0;

    while( true ){

        memset( visited, false, sizeof( visited ) );

        int f = find_flow( src, des, INF );

        if( f == 0 )
            return flow;

        flow += f;
    }

    return flow;

}


int main(){

    add_edge( 1, 2, 3 );
    add_edge( 1, 3, 3 );
    add_edge( 2, 3, 2 );
    add_edge( 2, 4, 3 );
    add_edge( 3, 5, 2 );
    add_edge( 5, 6, 3 );
    add_edge( 4, 5, 4 );
    add_edge( 4, 6, 2 );

    int flow = max_flow( 1, 6 );

    cout << flow << endl;

    return 0;
}


class Edge( object ):

    def __init__( self, u, v, cap ):
        self.src = u
        self.des = v
        self.cap = cap
        

    def __repr__( self ):
        return "%s -> %s( %s )"%( self.src, self.des, self.cap )


class FlowNetwork( object ):

    def __init__( self ):
        self.graph = {}
        self.flow  = {}
        

    def find_flow( self, src, des, path ):
        if src == des:
            return path
        for e in self.get_edges( src ):
            residuals = e.cap - self.flow[e]
            if residuals > 0 and e not in path:
                res = self.find_flow( e.des, des, path + [e] )
                if res != None:
                    return res
                

    def max_flow( self, src, des ):
        while True:
            path = self.find_flow( src, des, [] )
            if path == None:
                return sum( self.flow[e] for e in self.get_edges( src ) )
            residuals = [e.cap - self.flow[e] for e in path]
            flow = min( residuals )
            for e in path:
                self.flow[e]    += flow
                self.flow[e.re] -= flow
                

    def add_vertex( self, v ):
        self.graph[v] = []
        

    def add_edge( self, u, v, cap ):
        if u == v:
            raise ValueError( "u == v" )
        e     = Edge( u, v, cap )
        re    = Edge( v, u, cap )
        e.re  = re
        re.re = e
        self.graph[u].append( e )
        self.graph[v].append( re )
        self.flow[e]  = 0
        self.flow[re] = 0


    def get_edges( self, v ):
        return self.graph[v]


if __name__ == "__main__":
    
    g = FlowNetwork()
    
    for v in range( 1, 7 ):
        g.add_vertex( v )
        
    g.add_edge( 1, 2, 3 )
    g.add_edge( 1, 3, 3 )
    g.add_edge( 2, 3, 2 )
    g.add_edge( 2, 4, 3 )
    g.add_edge( 3, 5, 2 )
    g.add_edge( 5, 6, 3 )
    g.add_edge( 4, 5, 4 )
    g.add_edge( 4, 6, 2 )
    
    print g.max_flow( 1, 6 )
        


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Ford-Fulkerson算法是一种解决最大流问题算法,它通过不断寻找增广路径来增加流量,直到无法找到增广路径为止。在Matlab中,可以使用图论工具箱中的函数来实现Ford-Fulkerson算法,例如使用graph和maxflow函数。具体实现方法可以参考Matlab官方文档或相关教程。 ### 回答2: Ford-Fulkerson算法最大流问题的一种经典算法,用于确定一个网络中从源节点到汇节点的最大可行流量。下面我将简要介绍如何使用Matlab实现Ford-Fulkerson算法。 首先,我们需要定义一个图结构来表示网络。可以使用邻接矩阵来表示有向图,其中矩阵元素表示边的容量。源节点可以用一个预先定义的节点索引表示,汇节点也可以用另一个预先定义的节点索引表示。 接下来,我们可以实现Ford-Fulkerson算法的关键步骤。算法的主要思想是在剩余网络上找到增广路径,并在这条路径上增加流量,直到不能找到增广路径为止。 具体实现中可以使用深度优先搜索(DFS)或广度优先搜索(BFS)来找到增广路径。在每一次搜索过程中,我们需要判断当前节点是否已经被访问过,并且是否还可以通过当前边增加流量。 在找到增广路径后,我们可以计算出该路径上的最小容量(也称作瓶颈容量),并将该容量从剩余网络中减去。随后,我们将该容量添加到流网络中,并继续寻找新的增广路径。 当无法找到增广路径时,算法结束并返回最大流量值。最大流量值等于从源节点发出的所有流量之和。 综上所述,以上是在Matlab中实现Ford-Fulkerson算法的基本步骤。当然,具体实现中还需要考虑一些细节问题,并且可能需要调用一些Matlab内置的图算法函数来辅助实现。 ### 回答3: Ford-Fulkerson算法是用于最大流问题的一种常见算法,适用于有向图。算法的基本思想是不断在剩余网络中寻找一条增广路径,然后更新流量分布,直到无法找到增广路径为止。 在MATLAB中,可以使用图算法工具箱中的函数来实现Ford-Fulkerson算法。具体步骤如下: 1. 首先,需要创建一个有向图对象,并定义图中的节点和边。可以使用Graph对象来进行操作。 2. 然后,设置源节点和汇节点,即确定最大流的起点和终点。 3. 接下来,需要定义图中各个边的初始容量。可以使用addedge函数来添加边,并设置其容量。 4. 之后,可以使用fordfulkerson函数来解最大流。该函数会返回一个最大流值,同时也会更新图中各个边的流量。 5. 最后,可以使用findedge函数来查找某条边的流量。该函数需要指定边的起点和终点节点,返回对应边的流量值。 需要注意的是,Ford-Fulkerson算法的复杂度较高,最坏情况下为O(f * m),其中f为最大流值,m为边的数量。因此,在处理大规模图的情况下可能会面临一定的挑战。 以上是用MATLAB实现Ford-Fulkerson算法的简要过程。通过使用MATLAB的图算法工具箱,可以方便地对最大流问题进行解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值