Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Elimination left recursion for E := EE+|EE-|id

How to eliminate left recursion for the following grammar?

E := EE+|EE-|id

Using the common procedure:

A := Aa|b

translates to:

A := b|A'
A' := ϵ| Aa 

Applying this to the original grammar we get:

A = E, a = (E+|E-) and b = id

Therefore:

E := id|E'
E' := ϵ|E(E+|E-)

But this grammar seems incorrect because

ϵE+ -> ϵ id +

would be valid but that is an incorrect postfix expression.

like image 260
TheOne Avatar asked Dec 22 '22 08:12

TheOne


1 Answers

Your “common procedure” is cited wrong. Taking it from the Dragon Book:

A := Aα | β

becomes

A  := βA′
A′ := αA′ | ϵ

… which yields:

E  := id E′
E′ := (E + | E -) E′ | ϵ
like image 53
Konrad Rudolph Avatar answered Dec 26 '22 08:12

Konrad Rudolph