Exercise 01

Produce context-free grammars for the following languages. Replacement rules are all you need—it’s not necessary to write out complete 4-tuples.

  1. Problem A
  1. Problem B
  1. Problem C

Exercise 02

Context-free languages are close under union. That is, if and are context-free, then the language is also context-free.

Produce CFGs for the following languages, using the definitions from exercise 01:

  1. Problem A
  1. Problem B

Exercise 03

Prove that the following languages are context-free by providing context-free grammars that generate them.

  1. Problem A

Defining this with start symbol , nonterminals and to generate any number ‘s or the balanced part

We get:

  1. Problem B

Defining this with start symbol , nonterminals and to generate the balanced part or any number of ‘s


Exercise 04

Given the two languages, and from exercise 03, write the language using set builder notation.

To complete problem we let a string be , for the previously defined and

For String to be in :

  • must be integers and so that , , and

and thus the condition for is

For String to be in :

  • must be integers and so that , , and

and thus the condition for is

Therefore:


Exercise 05

Consider the language , which is not context-free

  1. How is this language similar to the language from exercises 03 and 04?
  2. What does this suggest about certain closure properties of context-free languages