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) What is a binary search tree?

b) Describe an algorithm for constructing a binary search tree.

c) Form a binary search tree for the words, vireo, warbler, egret, grosbeak, nuthatch, and kingfisher.

Short Answer

Expert verified

A binary search tree is a binary tree where each child is either the left or right child. A vertex cannot have more than one left child and cannot have more than one right child. The right child of a vertex has to be larger than the vertex, while the left child has to be smaller than the vertex.

First element in the list is named as the root.

Compare the element with the root of the tree. If the element is larger than the root, then move to the right child. If the element is smaller than the root, then move to the left child. Then repeat this step for the child.

When we move to a child, it is possible that there is no child yet and then the element needs to be added at that position in the tree.

A binary search tree for the words, vireo, warbler, egret, grosbeak, nuthatch, and kingfisher.

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

Binary tree

A tree is an undirected graph that is connected and that does not contain any simple circuits.

A binary search tree is a binary tree where each child is either the left or right child. A vertex cannot have more than one left child and cannot have more than one right child. The right child of a vertex has to be larger than the vertex, while the left child has to be smaller than the vertex.

02

Constructing binary tree

One first takes the first element as the root of the tree.

Then for all other elements, we repeatedly apply the following procedure:

Compare the element with the root of the tree. If the element is larger than the root, then move to the right child. If the element is smaller than the root, then move to the left child. Then repeat this step for the child.

When one moves to a child, it is possible that there is no child yet and then the element needs to be added at that position in the tree.

03

Vireo, warbler, egret, grossbeak

vireo, warbler, egret, grosbeak, nuthatch, king fisher

The root of the tree is the first element vireo.

warbler occurs after vireo in the alphabetical order; thus, warbler is the right child of vireo.

egret occurs before vireo in the alphabetical order; thus, egret is the left child of vireo.

grossbeak occurs before vireo in the alphabetical order; thus, we move on to the left child of vireo.

grossbeak occurs after egret in the alphabetical order; thus, grossbeak is the right child of egret.

04

Step 4:Nuthatch, kingfisher

nuthatch occurs before vireo in the alphabetical order; thus, we move on to the left child of vireo.

nuthatch occurs after egret in the alphabetical order; thus, we move on to the right child of egret.

nuthatch occurs after grossbeak in the alphabetical order; thus, nuthatch is the right child of grossbeak.

kingfisher occurs before vireo in the alphabetical order; thus, we move on to the left child of vireo.

kingfisher occurs after egret in the alphabetical order; thus, we move on to the right child of egret.

kingfisher occurs after grossbeak in the alphabetical order; thus, we move on to the right child of grossbeak.

kingfisher occurs before nuthatch in the alphabetical order; thus, kingfisher is the left child of nuthatch.

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