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 prefix code?

b) How can a prefix code be represented by a binary tree?

Short Answer

Expert verified

A prefix code is a coding of letters with the property that a bit string corresponding with a letter is never the beginning of a string of another letter.

One can encode a prefix code with a binary tree, by creating a rooted tree with two children. The edge of the left child is labeled \(0\) and the edge of the right child is labeled \(1\). Similarly, assign one or two children to every vertex until every path from the root to a leaf uniquely represents the encoding of a letter.

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 tree is an undirected graph that is connected and that does not contain any simple circuits.

The preorder traversal of a tree \({\bf{T}}\) with root \({\bf{r}}\) begins by visiting \({\bf{r}}\), then the most left subtree at \({\bf{r}}\) in preorder, then the second most left subtree at \({\bf{r}}\) in preorder, and so on.

A prefix code encodes letters such that the bit string for a letter never occurs as the beginning of the bit string for another letter.

02

Binary tree

One can encode a prefix code with a binary tree, by creating a rooted tree with two children. The edge of the left child is labeled \(0\) and the edge of the right child is labeled \(1\). Similarly, assign one or two children to every vertex until every path from the root to a leaf uniquely represents the encoding of a letter.

For example, the encoding \({\bf{a = 0, b = 10}}\) and \({\bf{c = 11}}\) can be represented by the following binary tree.

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