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/d23c0/d23c09cf7346e712638bca75c9f2ab84350b9860" 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/b7d2e/b7d2e688d0547ea22e4db956c595f73b1c381b38" 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/dac4a/dac4a87f7831d4a4046ee18be408d249b3c65fa9" 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/9c442/9c442a18c8aff7fce4fdb6a66172c839828108b4" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/2d68d/2d68d6a71ded0e06a92db74bc609039a07579d36" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/aa920/aa9205e8a489c74a880489b0423400b68867b20e" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/36a46/36a466ed3c43e3a1b5d6f603727922bcde87241e" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/06c25/06c2569d46ca1248e6070a371369142633a91d6b" alt="spanning tree spanning tree"
data:image/s3,"s3://crabby-images/d41d9/d41d9ce70aa6b6075f0fd043108e4b84e8626b3f" 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/2bc4f/2bc4f5baac2c63a4eff463ed46e2e83168b61336" alt="Initial weighted graph initial graph"
The possible spanning trees from the above graph are:
data:image/s3,"s3://crabby-images/3ec63/3ec63e0cf3e669fc714e8b5dd9a4e466b27d4342" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
data:image/s3,"s3://crabby-images/01985/01985105d4ab15c3f355194d050513891ebf2558" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
data:image/s3,"s3://crabby-images/eb3ab/eb3abdd3d75c23ff3570cbf92cbae2fa5addf7fe" alt="minimum spanning tree (mst) minimum spanning tree (mst)"
data:image/s3,"s3://crabby-images/6bef2/6bef2cb6fec84d8cb0d009448d9255507fb703bf" 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/f6c9a/f6c9a56454806f894dacc0e704cc2053248bfc71" 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.