Gomory-Hu tree. This algorithm is used to construct a general graph into a tree, weight of edges of the tree correspond to the weight of the cut set to disconnect adjacent vertices. The idea of this algorithm is very simple. At the beginning, pick two vertices arbitrarily, and compute the minimum cut between them. Then separate the graph into two groups, contract the edges in the cut set into a new edge e', and the weight of e' is the weight of the cut set. After that, in each iteration, pick two vertices from the same group, and find the minimum cut between them, then separate the group into two and contract the edges as before. It is obvious that this algorithm only need O(n) iterations of computing minimum cut. There are many variations of this algorithm to get a better time complexity, you can google it if you are interested in.
Stoer-Wagner's min-cut algorithm. This is the algorithm I implemented these days. The algorithm is based on a theorem. Let s and t be two vertices of graph G = (V, E). Let G/{s, t} be the graph obtained by contracting s and t. Then, a minimum cut of G can be obtained by taking the smaller of minimum s-t cut and minimum cut of G/{s, t}. By this theorem, Stoer and Wagner comes up an algorithm. In each iteration of the algorithm, get two vertices which have a minimum cut to separate them, then contract these two vertices. This algorithm follows the theorem stated above. If the minimum cut is not current s-t cut, then it should be in the graph G/{s, t}. The following is the pseudo code of this algorithm.
MinCutPhase(G, w, a):
A <- {a}
while (A != V)
x <- Most Tightly Connected Vertex
if (|A| == |V| - 2)
s <- x
if (|A| == |V| - 1)
t <- x
CurrentCut <- (A, complement of A)
add x to A
Contract(s, t)
return CurrentCut
MinCut (G, w, a):
while (|V| > 1)
CurrentCut <- MinCutPhase(G, w, a)
if (w(CurrentCut) < w(MinimumCut))
MinimumCut <- CurrentCut
In the pseudo code above, the definition of most tightly connected vertex x is:- x not in A s.t.
- w(A, x) = max { w(A, y) | y not in A }
Related Problems:
- Minimum Cut (from acm.pku.edu.cn)
- Bomb, Divide and Conquer (from acm.uva.es)
- Stoer, M. and Wagner, F. 1997. A simple min-cut algorithm. J. ACM 44, 4 (Jul. 1997), 585-591. DOI= http://doi.acm.org/10.1145/263867.263872
- Anne Loomis, Min cut, CS 105 (Winter 2005), Computer Science, Dartmouth College