Chapter 13: Q28E (page 857)
a) Explain what the productions are in a grammar if the Backus–Naur form for productions is as follows:
\(\begin{array}{*{20}{l}}{{\bf{ < expression > :: = }}\left( {{\bf{ < expression > }}} \right){\bf{ }}\left| {{\bf{ < expression > + < expression > }}} \right|}\\\begin{array}{c}{\bf{\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;}}\,\,\,\,{\bf{ < expression > * < expression > |}}\\\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,\,{\bf{ < variable > }}\end{array}\\{\,\,\,\,\,\,\,\,\,{\bf{ < variable > :: = xly}}}\end{array}\)
b) Find a derivation tree for \(\left( {{\bf{x*y}}} \right){\bf{ + x}}\) in this grammar.
Short Answer
(a) The productions of the grammar in the usual form are as follows:
expression \(\to\) (expression),
expression \(\to\) expression + expression,
expression \(\to\) expression * expression,
expression \(\to\) variable,
variable \(\to\) x
variable \(\to\) y
(b) The derivation tree for \(\left( {{\bf{x*y}}} \right){\bf{ + x}}\) is the following: