Why can't a recursive-descent parser handle left recursion

给你一囗甜甜゛ 提交于 2019-12-17 15:36:27

问题


Could someone please explain to me why recursive-descent parsers can't work with a grammar containing left recursion?


回答1:


consider:

A ::= A B

the equivalent code is

boolean A() {
    if (A()) {
        return B();
    }
    return false;
}

see the infinite recursion?




回答2:


For whoever is interested

 A ::= A B | A C | D | E

can be rewritten as:

 A ::= (D | E) (B | C)*

The general form of the transformation is: any one of the non left recursive disjuncts followed by any number of the left recursive disjuncts without the first element.

Reforming the action code is a bit trickery but I thing that can be plug-n-chug as well.



来源:https://stackoverflow.com/questions/847439/why-cant-a-recursive-descent-parser-handle-left-recursion

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!