- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为 k > 1 制作人工 LR(k) 文法很容易:
Input: A1 B x
Input: A2 B y (introduce reduce-reduce conflict for terminal a)
A1 : a
A2 : a
B : b b b ... b (terminal b occurs k-1 times)
但是,现实世界是否有 LR(k > 1) 可解析的非 LR(1) 计算机语言?
还是非 LR(1) 语言也不是 LR(k)?
最佳答案
如果一种语言有一个 LR(k)
文法,那么它就有一个 LR(1)
文法,它可以从 LR(k) )
语法;此外,可以从 LR(1)
解析树重新创建原始解析树。该定理的证明出现在 Parsing Theory Vol. 的第 6.7 节中。 II, Sippu & Soisalon-Soininen;他们将其归因于 MD Mickunas 在 JACM 23:17-30 中的“On the complete covering problem for LR(k) grammars”(1976 年)。
因此对于 k>1
没有可解析为 LR(k)
的语言,它也不能解析为 LR(1)
,并且因此,除了 0 和 1 之外,对于 k
的值,确实没有诸如 LR(k)
语言 之类的东西。
但是,对于某些语言,LR(2)
语法要容易得多。一个典型的例子是 yacc
的 Posix 语法,它不需要产生式以 ;
结束。这是明确的,因为产生式必须以标识符开头,后跟冒号。这样写,语法明明就是LR(2)
;根据上述定理,LR(1)
文法存在,但远没有那么干净。
关于parsing - 真实世界的 LR(k > 1) 文法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20207339/
我正在尝试实现一个表达式处理语法(处理嵌套括号和其他内容)。到目前为止我有以下内容,但它们无法处理某些情况(成功/失败情况出现在以下代码块之后)。有人知道这是怎么回事吗? 注意:varname +=
我在 ANTLR 语法中写下了以下语句: loopStatement : 'loop' (statement|exit)* 'end' 'loop' ';' ; 如果我没理解错的话,
为 C 的一个子集编写一个简单的 BNF 语法,它支持多个语句,包括赋值、if-else 和没有 block 语句的 while 语句。为你的非终结符使用有意义的名字(相对于神秘的字母)。假设变量由单
我正在尝试为以下语法创建一个 LALR(1) 解析器并发现一些移位/归约冲突。 S := expr expr := lval | ID '[' expr ']' OF expr lval := ID
根据这个paper的规则: If A is the start nonterminal, put EOF in FOLLOW(A) Find the productions with A on the
为 k > 1 制作人工 LR(k) 文法很容易: Input: A1 B x Input: A2 B y (introduce reduce-reduce con
在使用 make 和 bison 的项目中,我很难指定编译语法 grammar.tab.c 依赖于语法输入 grammar.y,每个目标文件都依赖于相应的源文件(包括 grammar.tab.o),并
我正在尝试从语法分析树中提取乔姆斯基范式 (CNF) - 句子的语法产生式: (ROOT (S (NP (DT the) (NNS kids)) (VP (VBD opened)
我知道 ANTLR 可以接受 LL(*) 文法。但是,有没有办法使用 ANTLR 检查语法是否是 LL(1)? 最佳答案 options { k = 1; } 如果您的语法不在 LL(1) 中,
我还没有找到答案。是否存在无法转换为 LL(1) 的上下文无关且无歧义的语法? 我发现了一个我不知道如何转换为 LL(1) 的作品:parameter-type-list C99中的生产: param
我是一名优秀的程序员,十分优秀!