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

Devise an algorithm for finding the second shortest spanning tree in a connected weighted graph.

Short Answer

Expert verified

Procedure maximum Kruskal (\(G\): weighted connected undirected graph with \({\bf{n}}\) vertices)

\({\bf{T: = }}\)empty graph

\(j{\bf{: = }}1\)

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

\({\bf{e: = }}\)edge in \(G\) of minimum weight not forming a simple circuit in \({\bf{T}}\)

(When the edge is added to \({\bf{T}}\)).

\({\bf{T: = }} \cup \{ e\} \)

\(\begin{array}{c}{\bf{P(j): = e}}\\{\bf{j: = j + 1}}\end{array}\)

for \({\bf{k: = 1}}\) to \({\bf{n - 1}}\)

\({\bf{S(k): = }}\)Remove \({\bf{P(k)}}\) from \({\bf{T}}\)

\({\bf{e: = }}\)edge in \(G\) of minimum weight not forming a simple circuit in \({\bf{S(k)}}\)

(When the edge is added to \({\bf{T}}\) and edge different from \({\bf{P(k)}}\)

\({\bf{S(k): = S(k}}) \cup \{ e\} \)

\({\bf{T: = }}\) Tree with minimal weight among the trees \({\bf{S(1),S(2), \ldots ,S(n - 1)}}\), return \({\bf{T}}\).

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.

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 \(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.

02

Step 2:Maximum Kruskal

One calls the procedure "maximum Kruskal" and the input is a weighted connected undirected graph with n vertices.procedure maximum Kruskal(\(G\): weighted connected undirected graph with \({\bf{n}}\) vertices) We initially \({\bf{T}}\) to be an empty graph. \({\bf{T: = }}\) empty graph A tree with n vertices contains \({\bf{n - 1}}\) edges and thus we need to add n-1 edges to \({\bf{T}}\). In each step, we search for the edge e with the smallest weight among all edges in \(G\) and this edgecannot form a simple circuit in \({\bf{T}}\) (when added to \({\bf{T}}\). When the edge e is found, we add it to the tree \({\bf{T}}\). \(j{\bf{: = }}\) for \({\bf{i = 1}}\) to \({\bf{n - 2}}\;\;\;{\bf{e: = }}\) edge in \(G\) of minimum weight not forming a simple circuit in \({\bf{T}}\) (when the edge is added to \({\bf{T}}\) .\({\bf{T: = }}T \cup \{ e\} ,\;{\bf{P(j): = e}},\;{\bf{j: = j + 1}}\) We have now obtained the least expensive tree and the edges were labeled with \({\bf{P(j)}}\).

03

Second least expensive

To find the second least expensive tree, we will delete every possible edge from the graph (separately) and determine the minimum spanning tree without this edge. Then we choose the network that is the cheapest out of these \({\bf{n - 1}}\) networks. for \({\bf{k: = 1}}\) to \({\bf{n - 1}}\)\({\bf{S(k): = }}\) Remove \({\bf{P(k)}}\) from \({\bf{T}},{\bf{e: = }}\)edge in \(G\) of minimum weight not forming a simple circuit in \({\bf{S(k)}}\) (when the edge is added to \({\bf{T}}\)) and edge different from \({\bf{P(k)}}\)

\(S(k): = S(k) \cup \{ e\} T: = \)Tree with minimal weight among the trees \({\bf{S(1),S(2), \ldots ,S(n - 1)}}\).

Finally, \({\bf{T}}\) should then contain the spanning tree that has the second least weight. return \({\bf{T}}\).

One App. One Place for Learning.

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

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free