Next: Maximum Flow
Up: A Tutorial on Network
Previous: Shortest Paths
Minimum Spanning Tree
The minimum spanning tree problem is to choose edges from an undirected
connected network so that every two nodes are connected by a path. The
objective is to choose edges with minimum total distance. It is intuitively
clear that such a set will not contain a cycle. Therefore, the set will
be a tree. This tree will connect (span) all the nodes.
This problem has a number of important practical applications. For example,
it can sometimes be helpful in planning transportation networks
that will not be used much. There, the primary consideration is to provide
some link between all pairs of nodes in the most economical way. Other
examples include the planning of large-scale communication models and distribution
networks.
The minimum spanning tree problem can be solved in a very straightforward
way because it is one of the few problems where being greedy at
each stage of a solution procedure still results in an optimal solution
at the end! The algorithm is as follows:
Greedy algorithm
-
Initialization The algorithm starts with no edge in the tree.
-
Iterative Step The edges are considered in increasing order of their
length. If an edge does not form a cycle with edges already in the tree,
add it to the tree. Otherwise, discard it.
-
Stopping Criterion: Stop when all nodes are connected.
Proof that the greedy algorithm finds a minimum spanning tree: Let
denote the tree found by the greedy algorithm and suppose some other tree
is shorter. We will show that this leads to a contradiction. Among the
trees which are shorter than the greedy solution
,
denote by T one which has the largest number of common edges with
.
Let a be a shortest edge in
but not in T and let C be the unique cycle formed when edge
a is added to the edges of T. The cycle C contains
at least one edge not in
,
say b, since
contains
no cycle. The length of a is less than or equal to that of b,
since edge a must have been considered before b by the greedy
algorithm. Now the tree
obtained from T by adding edge a and removing edge b
is of the same length as or shorter than T. Therefore
is shorter than
. But it
has one more edge in common with
,
a contradiction. This completes the proof.
Here's a different algorithm for finding a minimum spanning tree:
-
Select a node arbitrarily, and connect it to a node closest to it.
-
Identify an unconnected node that is closest to a connected node and add
the edge between them. Repeat until all nodes have been connected.
It may seem that it makes a difference which node to start at. It turns
out it doesn't (except for possibly finding alternative minimum spanning
trees). We omit the proof that this algorithm also gives an optimum solution
to the minimum spanning tree problem. In the homework and exam, you can
use either of these two algorithms to solve the problem.
Next: Maximum Flow
Up: A Tutorial on Network
Previous: Shortest Paths