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

Find a phrase-structure grammar that generates the set \(\left\{ {{{\bf{0}}^{{{\bf{2}}^{\bf{n}}}}}\mid {\bf{n}} \ge 0} \right\}\).

Short Answer

Expert verified

The phase-structure grammar:

\({\bf{G = }}\left( {{\bf{V, T, S, P}}} \right)\)

\({\bf{V = }}\left\{ {{\bf{S,0,1}}} \right\}\)Alphabet

\({\bf{T = }}\left\{ {{\bf{0,1}}} \right\}\)Set of terminal symbols

\({\bf{S}}\)Start symbol

Set of productions \({\bf{P}}\)

\(\begin{array}{l}{\bf{S}} \to {\bf{C0B}}\\{\bf{C}} \to {\bf{CA}}\\{\bf{C}} \to {\bf{\lambda }}\\{\bf{A0}} \to {\bf{00A}}\\{\bf{AB}} \to {\bf{B}}\\{\bf{B}} \to {\bf{\lambda }}\end{array}\)

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

An alphabet is a set of elements that can be used to construct strings.

A language is a subset of the set of all possible strings over an alphabet.

Phase structure grammar \(\left( {{\bf{V, T, S, P}}} \right)\) shows the description of a language, \({\bf{V}}\) is the alphabet, (T) is a set of terminal symbols, \({\bf{S}}\) is the start symbol and \({\bf{P}}\) is a set of productions.

02

Finding the phase-structure

It is given that \(\left\{ {{{\bf{0}}^{{{\bf{2}}^{\bf{n}}}}}\mid {\bf{n}} \ge 0} \right\}\).

The set of terminal symbols of all possible symbols in the resulting strings.

\({\bf{T = }}\left\{ {{\bf{0,1}}} \right\}\)

Let \({\bf{S}}\) be the start state.

It will construct the grammar by initially generating strings of the form \({\bf{AA \ldots A0B}}\) with zero or more \({\bf{A's}}\) on the left, a \(0\) in the middle and \({\bf{B}}\) on the right.

\({\bf{S}} \to {\bf{C0B}}\)

\(\begin{array}{l}{\bf{C}} \to {\bf{CA}}\\{\bf{C}} \to {\bf{\lambda }}\end{array}\)

03

Doubling the values

Next, it needs to cause the doubling of the \({\bf{0's}}\) using the \({\bf{A's}}\):

\({\bf{A0}} \to {\bf{00A}}\)

It will use this rule until the \({\bf{A's}}\) reach the \({\bf{B}}\) on the right. Once the \({\bf{A's}}\) reach the \({\bf{B's}}\), It absorbs the \({\bf{D's}}\) in the \({\bf{E's}}\).

\({\bf{AB}} \to {\bf{B}}\)

Finally, It needs to remove the \({\bf{B}}\) symbol, which is done by sending it to the empty string \({\bf{\lambda }}\).

\({\bf{B}} \to {\bf{\lambda }}\)

The alphabet \({\bf{V}}\) contains all symbols used in the production steps above.

\({\bf{V = }}\left\{ {{\bf{S, 0,1}}} \right\}\)

04

Combining the values

Combining all this information.

Therefore, it obtains the phase-structure grammar:

\({\bf{G = }}\left( {{\bf{V, T, S, P}}} \right)\)

\({\bf{V = }}\left\{ {{\bf{S, 0,1}}} \right\}\)Alphabet

\({\bf{T = }}\left\{ {{\bf{0,1}}} \right\}\)Set of terminal symbols

\({\bf{S}}\)Start symbol

Set of productions \({\bf{P}}\)

\(\begin{array}{l}{\bf{S}} \to {\bf{C0B}}\\{\bf{C}} \to {\bf{CA}}\\{\bf{C}} \to {\bf{\lambda }}\\{\bf{A0}} \to {\bf{00A}}\\{\bf{AB}} \to {\bf{B}}\\{\bf{B}} \to {\bf{\lambda }}\end{array}\)

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

Describe how productions for a grammar in extended Backusโ€“Naur form can be translated into a set of productions for the grammar in Backusโ€“Naur form.

This is the Backusโ€“Naur form that describes the syntax of expressions in postfix (or reverse Polish) notation.

\(\begin{array}{c}\left\langle {{\bf{expression}}} \right\rangle {\bf{ :: = }}\left\langle {{\bf{term}}} \right\rangle {\bf{|}}\left\langle {{\bf{term}}} \right\rangle \left\langle {{\bf{term}}} \right\rangle \left\langle {{\bf{addOperator}}} \right\rangle \\{\bf{ }}\left\langle {{\bf{addOperator}}} \right\rangle {\bf{:: = + | - }}\\\left\langle {{\bf{term}}} \right\rangle {\bf{:: = }}\left\langle {{\bf{factor}}} \right\rangle {\bf{|}}\left\langle {{\bf{factor}}} \right\rangle \left\langle {{\bf{factor}}} \right\rangle \left\langle {{\bf{mulOperator}}} \right\rangle {\bf{ }}\\\left\langle {{\bf{mulOperator}}} \right\rangle {\bf{:: = *|/}}\\\left\langle {{\bf{factor}}} \right\rangle {\bf{:: = }}\left\langle {{\bf{identifier}}} \right\rangle {\bf{|}}\left\langle {{\bf{expression }}} \right\rangle \\\left\langle {{\bf{identifier}}} \right\rangle {\bf{:: = a }}\left| {{\bf{ b }}} \right|...{\bf{| z}}\end{array}\)

Describe how Turing machines are used to compute number-theoretic functions.

Let \({\bf{G = }}\left( {{\bf{V, T, S, P}}} \right)\) be the context-free grammar with \({\bf{V = }}\left\{ {\left( {\bf{,}} \right){\bf{S,A,B}}} \right\}{\bf{, T = }}\left\{ {\left( {\bf{,}} \right)} \right\}\) starting symbol \({\bf{S}}\), and productions

Show that \({\bf{L}}\left( {\bf{G}} \right)\) is the set of all balanced strings of parentheses, defined in the preamble to Supplementary Exercise \(55\) in Chapter \(4\).

In Exercises 43โ€“49 find the language recognized by the given nondeterministic finite-state automaton.

Construct phrase-structure grammars to generate each of these sets.

a) \(\left\{ {{{\bf{1}}^{\bf{n}}}{\bf{|n}} \ge {\bf{0}}} \right\}\)

b) \(\left\{ {{\bf{1}}{{\bf{0}}^{\bf{n}}}{\bf{|n}} \ge {\bf{0}}} \right\}\)

c) \(\left\{ {{\bf{1}}{{\bf{1}}^{\bf{n}}}{\bf{|n}} \ge {\bf{0}}} \right\}\)

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