Before we learn about spanning trees, we need to understand two graphs: undirected graphs and connected graphs.
An undirected graph is a graph in which the edges do not point in any direction (ie. the edges are bidirectional).
data:image/s3,"s3://crabby-images/7a0a8/7a0a88691d31cdb665f7cd52bbbd79c53827ef0e" alt="Undirected Graph Undirected Graph"
A connected graph is a graph in which there is always a path from a vertex to any other vertex.
data:image/s3,"s3://crabby-images/1784f/1784f113b1360393a8c871f223e21244fb814dc0" alt="Connected Graph Connected Graph"
Spanning tree
A spanning tree is a sub-graph of an undirected connected graph, which includes all the vertices of the graph with a minimum possible number of edges. If a vertex is missed, then it is not a spanning tree.
The edges may or may not have weights assigned to them.
The total number of spanning trees with n
vertices that can be created from a complete graph is equal to n(n-2)
.
If we have n = 4
, the maximum number of possible spanning trees is equal to 44-2
= 16
. Thus, 16 spanning trees can be formed from a complete graph with 4 vertices.
Example of a Spanning Tree
Let's understand the spanning tree with examples below:
Let the original graph be:
data:image/s3,"s3://crabby-images/2c094/2c094039171b0a46c0111926e350282a1e8522c8" alt="normal graph initial tree"
Some of the possible spanning trees that can be created from the above graph are:
data:image/s3,"s3://crabby-images/91854/9185428cb86191ca5f8c86ea4e8de7bd1a838a38" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/d9e1d/d9e1df145284ee049b0be7c063df5ee228f27a2b" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/7984e/7984e599117ab2ef223dc71278cfb7d12af1131d" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/6c3d2/6c3d2e02b44d8285be1a9632fc9525b901b0ec4a" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/6aa13/6aa13a528297f11339e3ec74355d3857e9c8114d" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/694a3/694a341dd055b08c83b73287efd67b551c6a356f" alt="spanning tree spanning tree"
Minimum Spanning Tree
A minimum spanning tree is a spanning tree in which the sum of the weight of the edges is as minimum as possible.
Example of a Spanning Tree
Let's understand the above definition with the help of the example below.
The initial graph is:
data:image/s3,"s3://crabby-images/25801/2580106f83fe41c023b032baf2f4a45b649d71e4" alt="Initial weighted graph initial graph"
The possible spanning trees from the above graph are:
data:image/s3,"s3://crabby-images/1d45d/1d45d2b96decb5e1ea3f7a4685042e9c8c11b615" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
data:image/s3,"s3://crabby-images/73e39/73e39e9cda523f5416394f3cd6212741d630bf61" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
data:image/s3,"s3://crabby-images/12c12/12c12c582675aa3ded82533f9b977eb39225e5c7" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
data:image/s3,"s3://crabby-images/343bf/343bfc5e92ab6363f13b78544b512708ca7ff6e6" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
The minimum spanning tree from the above spanning trees is:
data:image/s3,"s3://crabby-images/37fc3/37fc35ff10645674f388ee7c66567c9d4acdd22f" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
The minimum spanning tree from a graph is found using the following algorithms:
Spanning Tree Applications
- Computer Network Routing Protocol
- Cluster Analysis
- Civil Network Planning
Minimum Spanning tree Applications
- To find paths in the map
- To design networks like telecommunication networks, water supply networks, and electrical grids.