Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

a. Describe Kruskal's algorithm and Prim's algorithm for finding minimum spanning trees.

b. Illustrate how Kruskal's algorithm and Prim's algorithm are used to find a minimum spanning tree, using a weighted graph with at least eight vertices and \(15\) edges.

Short Answer

Expert verified

Prim's algorithm:

Start from a graph that contains only the vertices and no edges, select a root, add the edge from the root to another vertex with the smallest weight.Repeatedly add the edge from a vertex in the already constructed tree to another vertex (not yet included in the tree) with the smallest weight.Once the graph is connected, we have found a minimum spanning tree.

Kruskal's algorithm:

Start from a graph\({\bf{T}}\)that contains only the vertices and no edges.Repeatedly select the edge in the given graph\({\bf{G}}\)with the smallest weight (that doesn't cause a circuit) and add it to the graph\({\bf{T}}\) .Once the graph is connected, we have found a minimum spanning tree.

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

Definition

A tree is an undirected graph that is connected and that does not contain any simple circuits.

A spanning tree of a simple graph \({\bf{G}}\) is a subgraph of \({\bf{G}}\) that is a tree and that contains all vertices of \({\bf{G}}\).

A minimum spanning tree of a weighted graph \({\bf{G}}\) is a spanning tree of \({\bf{G}}\) with minimal weight.

A graph is connected if there exists a path between every pair of vertices.

02

Prim’s and Kruskal’s algorithm

Prim's algorithm:

Start from a graph that contains only the vertices and no edges, select a root, add the edge from the root to another vertex with the smallest weight.Repeatedly add the edge from a vertex in the already constructed tree to another vertex (not yet included in the tree) with the smallest weight.Once the graph is connected, we have found a minimum spanning tree.

Kruskal's algorithm:

Start from a graph \({\bf{T}}\) that contains only the vertices and no edges.Repeatedly select the edge in the given graph \({\bf{G}}\) with the smallest weight (that doesn't cause a circuit) and add it to the graph \({\bf{T}}\) .Once the graph is connected, we have found a minimum spanning tree.

03

Prim’s algorithm

I will use the following graph with \(8\) vertices and \(15\) edges. The weights of all edges are all different (such that the algorithms are easier to apply).

04

Step 4:Obtaining the graph of Prim’s algorithm

Prim's algorithm:

\(\left\{ {{\bf{c, g}}} \right\}\)is the edge with smallest weight \(1\) , thus we add \(\left\{ {{\bf{c, g}}} \right\}\) to an empty graph.

\(\left\{ {{\bf{a, g}}} \right\}\)is the edge with smallest weight \(4\) (among the edges that were not included yet and those connected to a vertex in the previous graph), thus we add \(\left\{ {{\bf{a, g}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, h}}} \right\}\)is the edge with smallest weight \(2\) (among the edges that were not included yet and those connected to a vertex in the previous graph), thus we add \(\left\{ {{\bf{a, h}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, b}}} \right\}\)is the edge with smallest weight \(3\) (among the edges that were not included yet and those connected to a vertex in the previous graph), thus we add \(\left\{ {{\bf{a, b}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, f}}} \right\}\)is the edge with smallest weight \(5\) (among the edges that were not included yet and those connected to a vertex in the previous graph), thus we add \(\left\{ {{\bf{a, f}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, e}}} \right\}\)is the edge with smallest weight \(6\) (among the edges that were not included yet and those connected to a vertex in the previous graph), thus we add \(\left\{ {{\bf{a, f}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, d}}} \right\}\)is the edge with smallest weight \(7\) (among the edges that were not included yet and those connected to a vertex in the previous graph), thus we add \(\left\{ {{\bf{a, d}}} \right\}\) to the previous graph.

All vertices were then included in the graph and thus we obtained a spanning tree, which results in the following tree:

05

Obtaining the graph of Kruskal’s algorithm

Kruskal's algorithm:

\(\left\{ {{\bf{c, g}}} \right\}\)is the edge with smallest weight \(1\) , thus we add \(\left\{ {{\bf{c, g}}} \right\}\) to an empty graph.

\(\left\{ {{\bf{a, h}}} \right\}\)is the edge with smallest weight \(2\) (among the edges that were not included yet), thus we add \(\left\{ {{\bf{a, h}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, b}}} \right\}\)is the edge with smallest weight \(3\) (among the edges that were not included yet), thus we add \(\left\{ {{\bf{a, b}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, g}}} \right\}\)is the edge with smallest weight \(4\) (among the edges that were not included yet), thus we add \(\left\{ {{\bf{a, g}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, f}}} \right\}\)is the edge with smallest weight \(5\) (among the edges that were not included yet), thus we add \(\left\{ {{\bf{a, f}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, e}}} \right\}\)is the edge with smallest weight \(6\) (among the edges that were not included yet), thus we add \(\left\{ {{\bf{a, f}}} \right\}\) to the previous graph.

\(\left\{ {{\bf{a, d}}} \right\}\)is the edge with smallest weight \(7\) (among the edges that were not included yet), thus we add \(\left\{ {{\bf{a, d}}} \right\}\) to the previous graph.

All vertices were then included in the graph and thus we obtained a spanning tree, which results in the following tree:

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free