我在http://hackingoff.com/compilers/ll-1-parser-generator使用以下语法:
E -> T E'
E' -> + T E'
E' -> EPSILON
T -> F T'
T' -> * F T'
T' -> EPSILON
F -> ( E )
F -> id
输出解析表是
[
[0, "+", "*", "(", ")", "id", "$"],
[0, 0, 0, 0, 0, 0, 0],
[0, 10, 10, 1, 9, 1, 9],
[0, 2, 10, 10, 3, 10, 3],
[0, 9, 10, 4, 9, 4, 9],
[0, 6, 5, 10, 6, 10, 6],
[0, 9, 9, 7, 9, 8, 9]
]
有人可以解释一下解析表吗?特别是,9
和10
的含义是什么,因为生产规则中只有8行
答案 0 :(得分:1)
它在页面本身中解释,就在表格上方:
如果非终端的预测集中没有终端,则会在表中放置错误代码。如果该终端在跟随(非终端),则该错误是POP错误。否则,这是一个SCAN错误。
POP错误代码=预测表格产品数量+ 1
SCAN错误代码=预测表格产品数量+ 2
因此,对于具有八个生产规则的语法,值9和10分别为POP error
和SCAN error
。