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

Give production rules in Backus–Naur form for the name of a person if this name consists of a first name, which is a string of letters, where only the first letter is uppercase; a middle initial; and a last name, which can be any string of letters.

Short Answer

Expert verified

The production rules in Backus–Naur form for the name of a person.

\(\begin{array}{l}{\bf{ < first name > < middle name > < last name > }}\\{\bf{ < uppercase letter > letter string < middle name > < last name > }}\\{\bf{J < letter string > < middle name > < last name > }}\\{\bf{James < middle name > < last name > }}\\{\bf{James k < last name > }}\\{\bf{James k roggs}}{\bf{.}}\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

About Backus-Nour form

A type-2 grammar is designated by the notation known as Backus-Naur form.

The left side of a type 2 grammar's production is one non-terminal symbol.

It can merge all of the productions into a single statement using the same left non-terminal symbolàrather than listing each one separately in production,

It use the symbol:: =

Enclose all non-terminal symbols in brackets <>, and it list all right-hand sides of productions in the same statement, separating them by bars.

02

Backus-Naur form of productions of the grammar.

It ignores the spaces between names and assume that the name is not empty. The grammar can be written as:

\(\begin{array}{c}{\bf{ < person > :: = < first name > < middle name > < last name > }}\\{\bf{ < last name > :: = < letter string > }}\\{\bf{ < middle name > :: = < letter > }}\\{\bf{ < first name > :: = < uppercase letter > | < uppercase letter > letter string }}\\{\bf{ < letter string > :: = < letter > | < letter string > < letter > }}\\{\bf{ < letter > :: = < lowercase letter > I < uppercase letter > }}\\{\bf{ < lowercase letter > :: = a|b|c|}}...{\bf{|z}}\\{\bf{ < uppercase letter > :: = A|B|C|}}...{\bf{|Z }}\end{array}\)

03

Let’s describe all production,

The first production tells that a person has a first name, middle name and last name.

The second production shows that the last name is a letter string.

The third production shows that the middle name can be any letter that is an uppercase letter or lowercase letter.

The fourth production shows that the first name consists of a string of one or more letters with the first letter being an uppercase letter.

The fifth production shows that a letter string can be a letter or a letter string followed by a letter.

The sixth production shows that a letter can be in lowercase or uppercase.

The seventh and eighth productions define the non-terminal lowercase letter and uppercase letters.

04

For example, James k roggs can be produced using the following steps,

Using first production, it replaces < person > with

< first name >< middle name >< last name >

Using fourth production, it gets

< uppercase letter > letter string < middle name >< last name >

Using Eighth production, it gets

J < letter string >< middle name >< last name >

Fifth, sixth and seventh production gives us

James < middle name >< last name>

From third, sixth and seventh production,

James k < last name>

From 2nd, 5th, 6th & 7th production, it gets

James k roggs.

Hence, the production rules in Backus–Naur form for the name of a person.

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

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