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 constructing a rooted tree from the universal addresses of its leaves.

Short Answer

Expert verified

Therefore, the algorithm for a set of universal addresses

Proceduretree(S: list of universal addresses)

S := S in lexicographic ordering

T := tree with one vertex with label 0 (the root)

for every universal address \({\bf{s = }}{{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{\bf{n}}}\) in S

for i :=1 to n

if there is no vertex with address \({{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{\bf{i}}}\)then

if i := 1 then

T:= T with a child labelled \({{\bf{s}}_{\bf{1}}}\) added to the root

Else

T := T with a child labelled \({{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{\bf{i}}}\) added

to the vertex with label \({{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{{\bf{i - 1}}}}\)

Return value

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

General form

Definition of tree: A tree isa connected undirected graph with no simple circuits.

Definition of Circuit: It isa path that begins and ends in the same vertex.

Definition of rooted tree: A rooted tree is a tree in which one vertex has been designated as the root and every edge is directed away from the root.

Level order (Definition): The listing of the vertices of an ordered rooted tree in level order begins with the root, followed by the vertices at level 1 from left to right, followed by the vertices at level 2 from left to right, and so on.

Universal address system (Definition):

  1. Label the roots with the integer 0. Then label its k children (at level 1) from left to right with 1, 2, 3, …, k.

For each vertex v at level n with label A, label its \({{\bf{k}}_{\bf{v}}}\)children, as they are drawn from left to right, with \({\bf{A}}{\bf{.1,A}}{\bf{.2,}}...{\bf{,A}}{\bf{.}}{{\bf{k}}_{\bf{v}}}\).

02

Algorithm of ordered rooted tree

Let us name the algorithm as “tree” and the input of the algorithm is list of universal addresses.

Procedure tree(S: list of universal addresses)

We will first order the universal addresses in lexicographic ordering (if this hasn’t occurred already)

S := S in lexicographic ordering

First, we add a root to the tree T. Next, for every universal address \({\bf{s = }}{{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{\bf{n}}}\) in S

for i := 1 to n

if there is no vertex with address \({{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{\bf{i}}}\) then

if i := 1 then

T:= T with a child labelled \({{\bf{s}}_{\bf{1}}}\)added to the root

Else

T := T with a child labelled\({{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{\bf{i}}}\) added

to the vertex with label \({{\bf{s}}_{\bf{1}}} \cdot {{\bf{s}}_{\bf{2}}} \cdot {{\bf{s}}_{\bf{3}}} \cdot ... \cdot {{\bf{s}}_{{\bf{i - 1}}}}\)

Finally, we return the tree T that was constructed.

return T

Conclusion: The algorithm for construction a rooted tree from the universal addresses of its leaves is founded.

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