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 two different algorithms for finding a spanning tree in a simple graph.

b. Illustrate how the two algorithms you described in part \(\left( {\bf{a}} \right)\) can be used to find the spanning tree of a simple graph, using a graph of your choice with at least eight vertices and \(15\) edges.

Short Answer

Expert verified

a. Depth-first search and Breadth-first search

b. Answers could vary

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 graph is connected if there exists a path between every pair of vertices.

02

Depth-first and Breadth-first search

Depth-first search:

Choose a root, add an edge to the first vertex that is adjacent to the root.We will create a path by repeatedly adding an edge to the first vertex adjacent to the previous vertex (that was not included in thetree yet).If no longer possible to add edges in this manner, then backtrack to the last vertex that was adjacent to a vertex not included in the tree yet. Then create a path in the same manner as above. Repeat until every vertex is obtained in the tree.

Breadth-first search:

Choose a root, add all edges incident to the root (vertices will be at level \(1\) in the tree).For each of the vertices at level \(1\) , add all edges incident with a vertex not included in the tree yet.Repeat until all vertices were added to the tree.

03

Spanning tree of a simple graph

I will use the following graph with \(8\) vertices and \(15\) edges:

04

Depth-first search

Depth-first search

I choose vertex \(\left( {\bf{a}} \right)\) as the root.

\(\left( {\bf{a}} \right)\)is connected to all other vertices \({\bf{b, c, d, e, f, g, h}}\), then we add the first vertex \(\left( {\bf{b}} \right)\) in alphabetical order and thus add \(\left( {{\bf{a, b}}} \right)\) to an empty graph.

\(\left( {\bf{b}} \right)\)is connected to \(\left( {\bf{c}} \right)\) and \({\bf{h }}{\bf{. c}}\) occurs first in alphabetical order and thus we add \(\left( {{\bf{b, c}}} \right)\) to the previous graph.

\(\left( {\bf{c}} \right)\)is connected to \(\left( {\bf{d}} \right)\)and \({\bf{g }}{\bf{. d}}\) occurs first in alphabetical order and thus we add \(\left( {{\bf{c, d}}} \right)\) to the previous graph.

\(\left( {\bf{d}} \right)\)is connected to \(\left( {\bf{e}} \right)\) and thus we add \(\left( {{\bf{d, e}}} \right)\) to the previous graph.

\(\left( {\bf{e}} \right)\)is connected to \(\left( {\bf{f}} \right)\) and thus we add \(\left( {{\bf{e, f}}} \right)\) to the previous graph.

\(\left( {\bf{f}} \right)\)is connected to \(\left( {\bf{g}} \right)\) and thus we add \(\left( {{\bf{f, g}}} \right)\) to the previous graph.

\(\left( {\bf{g}} \right)\)is connected to \(\left( {\bf{h}} \right)\) and thus we add \(\left( {{\bf{g, h}}} \right)\) to the previous graph.

All vertices were added to the graph and thus the resulting graph (given below) is the spanning tree.

05

Breadth-first search

Breath-first search

- I choose vertex \(\left( {\bf{a}} \right)\) as the root.

- \(\left( {\bf{a}} \right)\) is connected to all other vertices \({\bf{b, c, d, e, f, g, h}}\), thus we add all edges incident to \(\left( {\bf{a}} \right)\)to an empty graph.

All vertices were added to the graph and thus the resulting graph (given below) is the spanning 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