|   |     | 
| (3 intermediate revisions by the same user not shown) | 
| Line 1: | Line 1: | 
|  | {{TOCright}}
 |  | #REDIRECT [[ist:Top-Down Parsing/Exercise 7]] | 
|  | = Problem =
 |  | 
|  |   |  | 
|  | Consider the following grammar, where '''<tt>A</tt>''' is the initial symbol and '''<tt>{a,b,c,d,e}</tt>''' is the set of terminal symbols:
 |  | 
|  |   |  | 
|  |  X -> a
 |  | 
|  |  A -> X c A e | M b
 |  | 
|  |  M -> A c | X c d | (eps)
 |  | 
|  |   |  | 
|  | # Examine the grammar and rewrite it so that an LL(1) predictive parser can be built for the corresponding language.
 |  | 
|  | # Compute the FIRST and FOLLOW sets for all non-terminal symbols in the new grammar and build the parse table.
 |  | 
|  | # Show the analysis table (stack, input, and actions) for the parsing process of the '''<tt>acbe</tt>''' input sequence. |  | 
|  |   |  | 
|  | == Solution ==
 |  | 
|  |   |  | 
|  | [[Image:CompilersTopDownParsingExercise7.jpg|700px]] |  | 
|  |   |  | 
|  | [[category:Teaching]]
 |  | 
|  | [[category:Compilers]]
 |  |