Prerequisite – Pushdown automata, Pushdown Automata Acceptance by Final State

**Problem:** Design a non deterministic PDA for accepting the language , i.e.,

L = {abc, aabc, aabbcc, abbbccc, aabbbccc ...... }

The following DFA must contain:

- The number of a’s is equal to number of c’s.
- The number of b’s is independent of the number of a’s and c’s.
- Order of a, b and c must be maintained.

**Explanation:**

The order of a’s, b’s and c’s is maintained as follows that is, all the a’s are are coming first and then all the b’s and then c’s are coming. Since the number of b’s is exactly equal to the number of c’s.So, the count of b’s and c’s will maintained by the stack. Stack used will have a start symbol and extra symbol for count of b’s and c’s.

= { a, z }

Where, = set of all the stack alphabet.

z = stack start symbol.

**Approach used in the construction of PDA –**

**Step-1:**Whenever ‘a’ comes then push it in stack and if again ‘a’ comes then also push it.**Step-2:**When ‘c’ comes then pop one ‘a’ from the stack each time.**Step-3:**When ‘b’ comes then ignore it and change the state in state diagram.**Step-4:**Stop the execution if at the end, the stack becomes empty.Thus the string is accepted by the PDA.

Note that there always maintains the order of a, b and c.

**Stack transition functions:**

(q0, a, z) (q0, z) (q0, b, z) (q1, bz) (q1, b, b) (q1, bb) (q1, c, b) (q2, ) (q2, c, b) (q2, ) (q2, , z) (qf, z)

**State transition diagram:**

Here, q0 = Initial state

qf = Final state

= indicates pop operation

And, q1,q2= Intermediate State

Attention reader! Don’t stop learning now. Get hold of all the important DSA concepts with the **DSA Self Paced Course** at a student-friendly price and become industry ready.

## Recommended Posts:

- NPDA for accepting the language L = {a
^{m}b^{(2m+1)}| m ≥ 1} - NPDA for accepting the language L = {a
^{m}b^{n}c^{p}d^{q}| m+n=p+q ; m,n,p,q>=1} - NPDA for accepting the language L = {a
^{m}b^{(m+n)}c^{n}| m,n ≥ 1} - NPDA for accepting the language L = {a
^{(m+n)}b^{m}c^{n}| m,n ≥ 1} - NPDA for accepting the language L = {a
^{n}b^{(2n)}| n>=1} U {a^{n}b^{n}| n>=1} - NPDA for accepting the language L = {a
^{i}b^{j}c^{k}d^{l}| i==k or j==l,i>=1,j>=1} - NPDA for accepting the language L = {a
^{2m}b^{3m}| m ≥ 1} - NPDA for accepting the language L = {a
^{n}b^{m}| n,m ≥ 1 and n ≠ m} - NPDA for accepting the language L = {a
^{n}b^{m}c^{n}| m,n>=1} - NPDA for accepting the language L = {a
^{n}b^{n}| n>=1} - NPDA for accepting the language L = {a
^{n}b^{n}c^{m}| m,n>=1} - NPDA for accepting the language L = {a
^{m}b^{n}c^{(m+n)}| m,n ≥ 1} - NPDA for accepting the language L = {a
^{m}b^{(2m)}| m>=1} - NPDA for accepting the language L = {wwR | w ∈ (a,b)*}
- NPDA for the language L ={w∈ {a,b}*| w contains equal no. of a's and b's}
- DFA for accepting the language L = { a
^{n}b^{m}| n+m=even } - DFA for accepting the language L = {a
^{n}b^{m}| n+m=odd} - NPDA for L = {0
^{i}1^{j}2^{k}| i==j or j==k ; i , j , k >= 1} - NFA machines accepting all strings that ends or not ends with substring 'ab'
- DFA machines accepting odd number of 0’s or/and even number of 1’s

If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.