从唐纳德·克努斯(Donald
Knuths)谈抽象的语言从左到右,
结果表明,对于 某个k而言 ,语法是否为LR(k)的问题尚不确定,
换一种说法,
给定语法G,“ ∃k.G∊LR(k)”是不确定的。
因此, 一般而言 , 我们能做的最好的事情是尝试为LR(0),然后为LR(1),LR(2)等构造一个解析器。有时,您将成功,或者当 k
时,您可能会放弃变大。
在这种情况下,我碰巧知道您给出的语法是LALR(1),这意味着它必须是LR(1)。我知道这是因为我已经为类似的语言编写了LALR解析器。出于显而易见的原因,它不能是LR(0)(语法{A->
x,A-> A + x}不是LR(0))。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)