- Edmonds-Karp algorithm
In
computer science andgraph theory , the Edmonds-Karp algorithm is an implementation of the Ford-Fulkerson method for computing the maximum flow in aflow network in . It is asymptotically slower than therelabel-to-front algorithm , which runs in , but it is often faster in practice forsparse graph s. The algorithm was first published by a Russian scientist, Dinic, in 1970 [cite journal | last = E. A. Dinic | title = Algorithm for solution of a problem of maximum flow in a network with power estimation | journal = Soviet Math. Doklady | volume = Vol 11 | issue = | pages = 1277–1280 | publisher = Doklady | date = 1970 | url = | doi = | id = | accessdate = ] , and independently byJack Edmonds andRichard Karp in 1972 [cite journal | author =Jack Edmonds and Richard M. Karp | title = Theoretical improvements in algorithmic efficiency for network flow problems | journal = Journal of the ACM | volume = 19 | issue = 2 | pages = 248–264 | publisher = | date = 1972 | url = http://www.akira.ruc.dk/~keld/teaching/algoritmedesign_f03/Artikler/08/Edmonds72.pdf | doi = | id = | accessdate = ] (discovered earlier). Dinic's algorithm includes additional techniques that reduce the running time to .Algorithm
The algorithm is identical to the
Ford-Fulkerson algorithm ,except that the search order when finding theaugmenting path isdefined. The path found must be the shortest path which hasavailable capacity. This can be found by abreadth-first search , as we let edges have unit length. The running time of is found by showing that each augmenting pathcan be found in time, that every time at least one of the edge becomes saturated, that the distance from thesaturated edge to the source along the augmenting path must belonger than last time it was saturated, and that the distance isat most long. Another property of this algorithm isthat the length of the shortest augmenting path increasesmonotonically. There is an accessible proof in [cite book
author =Thomas H. Cormen ,Charles E. Leiserson ,Ronald L. Rivest andClifford Stein | title =Introduction to Algorithms | publisher = MIT Press and McGraw-Hill | year = 2001
id = ISBN 0-262-53196-8 | edition = second edition | chapter =26.2 | pages = 660-663 ] .Pseudocode
:"For a more high level description, see
Ford-Fulkerson algorithm .algorithm EdmondsKarp input: C [1..n, 1..n] "(Capacity matrix)" E [1..n, 1..?] "(Neighbour lists)" s "(Source)" t "(Sink)" output: f "(Value of maximum flow)" F "(A matrix giving a legal flow with the maximum value)" f := 0 "(Initial flow is zero)" F := array(1..n, 1..n) "(Residual capacity from u to v is C [u,v] - F [u,v] )" forever m, P := BreadthFirstSearch(C, E, s, t) if m = 0 break f := f + m "(Backtrack search, and write flow)" v := t while v ≠ s u := P [v] F [u,v] := F [u,v] + m F [v,u] := F [v,u] - m v := u return (f, F) algorithm BreadthFirstSearch input: C, E, s, t output: M [t] "(Capacity of path found)" P "(Parent table)" P := array(1..n) for u in 1..n P [u] := -1 P [s] := -2 "(make sure source is not rediscovered)" M := array(1..n) "(Capacity of found path to node)" M [s] := ∞ Q := queue() Q.push(s) while Q.size() > 0 u := Q.pop() for v in E [u] "(If there is available capacity, and v is not seen before in search)" if C [u,v] - F [u,v] > 0 and P [v] = -1 P [v] := u M [v] := min(M [u] , C [u,v] - F [u,v] ) if v ≠ t Q.push(v) else return M [t] , P return 0, P
Example
Given a network of seven nodes, source A, sink G, and capacities as shown below:
In the pairs written on the edges, is the current flow, and is the capacity. The residual capacity from to is , the total capacity, minus the flow that is already used. If the net flow from to is negative, it "contributes" to the residual capacity.
Notice how the length of the
augmenting path found by the algorithm (in red) never decreases. The paths found are the shortest possible. The flow found is equal to the capacity across the minimum cut in the graph separating the source and the sink. There is only one minimal cut in this graph, partitioning the nodes into the sets and , with the capacity .Java Implementation
References
# Algorithms and Complexity (see pages 63 - 69). http://www.cis.upenn.edu/~wilf/AlgComp3.html
Wikimedia Foundation. 2010.