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 determining if a set of universal addresses can be the addresses of the leaves of a rooted tree.

Short Answer

Expert verified

Therefore, the algorithm for a set of universal addresses

Procedure leaves(S: list of universal addresses)

S := S in lexicographic ordering

Value := true

for every universal address s in S

If s is the prefix of another universal address in S then value := false

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

For all positive integers b smaller than \({{\bf{s}}_{\bf{i}}}\)

If s is NOT the prefix of another universal address in S then

Value := false

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 is a 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 isa 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 “leaves” and the input of the algorithm is list of universal addresses.

Procedure leaves(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

Next we check that none of the addresses are the prefix of another address in the list (which cannot be possible as a leave cannot have children).

If we find such an address that is the prefix of another address in the list, then we retrun false to indicate that the list of universal addresses cannot be the leaves of a rooted tree.

Value := true for every universal address s in S

If s is the prefix of another universal address in S then value := false

Finally, we also need to make sure all internal vertices have a descendant.

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

For all positive integers b smaller than \({{\bf{s}}_{\bf{i}}}\)

If s is NOT the prefix of another universal address in S then

Value := false

Finally, we return the value value, which will contain false if the list of universal addressed cannot form the leaves of a rooted tree and else will contain true.

Return value

Conclusion: The algorithm for determining a set of universal addresses can be the addresses of the leaves of a rooted tree 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