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

Express Sollin’s algorithm in pseudo code.

Short Answer

Expert verified

Procedure \({\bf{Sollin}}\left( {\bf{G}} \right)\): connected simple graph with vertices \({{\bf{v}}_{\bf{1}}}{\bf{,}}{{\bf{v}}_{\bf{2}}}{\bf{, \ldots ,}}{{\bf{v}}_{\bf{n}}}\) and \({\bf{n}} \ge {\bf{1}}\)

for \({\bf{i = 1}}\) to \({\bf{n}}\)

\({{\bf{T}}_{\bf{i}}}\)Tree with only the vertex \({{\bf{v}}_{\bf{i}}}\) (and no edges)

While Set of trees \({\bf{ > 1}}\)

for every tree \({{\bf{T}}_{\bf{i}}}\) in the set of trees

\({{\bf{e}}_{\bf{i}}}{\bf{: = }}\)shortest edge from a vertex in \({{\bf{T}}_{\bf{i}}}\) to a vertex not in \({{\bf{T}}_{\bf{i}}}\)

Set of trees\({\bf{: = }}\)Add all \({{\bf{T}}_{\bf{i}}}\)'s to the trees in the set of trees

return Set of trees

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

Sollin's algorithm:

Let all vertices be ordered (which also produces a lexicographic ordering of the edges). Simultaneously choose the edge of least weight incident to every vertex (In case of ties, use the first edge in the ordering). Simultaneously choose an edge from a vertex in each tree (result of previous step) to a vertex in a different tree with minimum weight (In case of ties, use the first edge in the ordering). Repeat until \({\bf{n - 1}}\) edges were chosen.

02

Using Sollin algorithm

One calls the algorithm "Sollin" and the input is a connected simple graph \({\bf{G}}\) (note: if the graph is not connected, then the algorithm will never end). procedure \({\bf{Sollin}}\left( {{\bf{G:connectedsimple}}} \right)\) graph with vertices \({{\bf{v}}_{\bf{1}}}{\bf{,}}{{\bf{v}}_{\bf{2}}}{\bf{, \ldots ,}}{{\bf{v}}_{\bf{n}}}\) and\({\bf{n}} \ge {\bf{1}}\) Initially, we create a set of trees with every tree containing exactly one vertex of\({\bf{G}}\).\({\bf{for i: = 1 to n (}}{{\bf{T}}_{\bf{i}}}{\bf{: = )}}\)Tree with only the vertex \({{\bf{v}}_{\bf{i}}}\) (and no edges) Set of trees \({\bf{: = }}{{\bf{T}}_{\bf{1}}}{\bf{,}}{{\bf{T}}_{\bf{2}}}{\bf{, \ldots ,}}{{\bf{T}}_{\bf{n}}}\) As long as we have more than one tree,

one determines the shortest edge from a vertex in each tree to a vertex in another tree.

03

Add the edges

Then one adds these edges to the trees and reorganize the new set of trees. while Set of trees\(3{\bf{ > 1}}\) for every tree \({{\bf{T}}_{\bf{i}}}\) in the set of trees while,Set of trees \({\bf{ > 1}}\;\;\;\) for every tree \({{\bf{T}}_{\bf{i}}}\) in the set of trees \({{\bf{e}}_{\bf{i}}}{\bf{: = }}\) shortest edge from a vertex in \({{\bf{T}}_{\bf{i}}}\) to a vertex not in \({\bf{(}}{{\bf{T}}_{\bf{i}}}{\bf{)}}\) Set of trees: \({\bf{ = }}\) Add all \({{\bf{e}}_{\bf{i}}}\)'s to the trees in the set of trees (and relabel such that each new tree is mentioned only once). Finally, one returns the set of trees (since the set of trees should contain only one tree when the while-loop ends. return Set of trees.

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