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 informal English descriptions of PDAs for the languages in Exercise 2.6

Give context-free grammars generating the following languages.

a. The set of strings over the alphabet a,bwith more a's than b's

b. The complement of the language anbnn0.

c. w#xwRis a substring of x for w,x 0,1*

d. localid="1662105288591" x1#x2#...#xkk1,each xilocalid="1662105304877" a,b*,and for some i and j ,localid="1662105320570" xi=xjR

Short Answer

Expert verified
  1. The informal english descriptions of pushdown deterministic automata for the language a,b,a's than b's is given below.
  2. The informal english descriptions of pushdown deterministic automata for the language anbnn0is given below.
  3. The informal english descriptions of pushdown deterministic automata for the language w#xwRis a substring of x for w,x 0,1*is given below.
  4. The informal english descriptions of pushdown deterministic automata for the languagex1#x2#...#xkk1,eachxia,b*and for some i and j ,xi=xjR is given below.

Step by step solution

01

Define PDA

Pushdown Automata is a finite automata with extra memory called stack which helps Pushdown automata to recognize Context Free Languages. Context free language is a grammar where its language or string that formed by context free grammar is supports pushdown deterministic automata. Context free grammar is used to generate context free languages. A context free grammar is a formal grammar which is used to generate all the possible patterns of strings in a given formal language. And it is contained number of sets of production rules.

02

Explanation

a)

The informal english descriptions ofpushdown deterministic automatafor the language{a,b}, a's than b's is given below.

The pushdown deterministic automata uses its stack to count the number of a's minus the number of b's . It enters an accepting state whenever this count is positive. In more detail, it operates as follows.

The pushdown deterministic automata scan across the input. If it sees a b's and its top stack symbol is an a, it pops the stack.

Similarly, if it scans an a and its top stack symbol is a b, it pops the stack. In all other cases, it pushes the input symbol onto the stack.

After the pushdown deterministic automata finishes the input, if a is on top of the stack, it accepts. Otherwise it rejects.

03

Explanation of part (b).

b)

The informal english descriptions ofpushdown deterministic automatafor the language{anbnn0}is given below.

For the complement of the language,{anbnn0}.

Push the $ onto the stack so that we know when we are at the empty stack. If the stack is empty or there is an’a’ at the top of the stack, and we read an ’a ’, then push an ’a ’ onto the stack for each a that is read on the input string.

If the stack is empty, or there is a ’b’ at the stop of the stack and we read a ’b ’, then push two ’b’s onto the stack for each ’b’ that is read. If there are two ’a” s at the top of the stack, and we read a ’b’, then pop the two’a ” s as we read the ’b’.

Otherwise if there is only one ’a ’ on the top of the stack, pop that ’a’ and push one ’b’ onto the stack. If there is a ’b’ at the top of the stack and we read an ’a’, the pop the ’b’ for each ’a ’ that is read.

Finally, if the top of the stack is the dollar sign, then non-deterministically branch (without reading any new input) to the accept state.

04

Explanation of part (c).

(c)

The informal english descriptions ofpushdown deterministic automatafor the language{w#xwRis a substring of x for w, x{0,1}*}is given below.

{w#xwRis a substring of x for w, x {0,1}*}

The pushdown deterministic automata scans across the input string and pushes every symbol it reads until it reads a# .

If a# is never encountered, it rejects. Then, the pushdown deterministic automata skip over part of the input, non deterministically deciding when to stop skipping.

At that point, it compares the next input symbols with the symbols it pops off the stack. At any disagreement, or if the input finishes while the stack is nonempty, this branch of the computation rejects.

If the stack becomes empty, the machine reads the rest of the input and accepts.

05

Explanation of part (d).

d)

The informal english descriptions ofpushdown deterministic automatafor the language{x1#x2#...#Xkk1,eachxia,b*}, and for some i and j,xi=xjRis given below.

The pushdown deterministic automata uses its stack to count the number of a's minus the number of b's. It enters an accepting state whenever this count is positive. In more detail, it operates as follows.

The pushdown deterministic automata scan across the input. If it sees a b'sand its top stack symbol is an a, it pops the stack.

Similarly, if it scans an a and its top stack symbol is ab, it pops the stack. In all other cases, it pushes the input symbol onto the stack.

After the pushdown deterministic automata finishes the input, ifa is on top of the stack, it accepts. Otherwise it rejects.

{x1#x2#...#xkk1,eachxi{a,b}*,and for some i and j ,xi=xjR

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