首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在LR(0)文法中处理可空生成

在LR(0)文法中处理可空生成
EN

Stack Overflow用户
提问于 2014-10-22 22:14:47
回答 1查看 1.3K关注 0票数 2

我认为这是一个非常简单的问题,但我在任何地方都找不到答案。

如果我有一个带有派生空的非终端的语法,如下所示:

  1. S -> B$
  2. B -> idP
  3. P -> (E)
  4. P ->
  5. E -> B

如何处理生产#3来绘制它的LR(0)状态?是否必须在LR(0)解析表中包含与转换对应的列?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-22 23:06:50

item P -> ·与右侧·的任何其他项目没有什么不同;在·之前没有任何东西使它变得特殊。项目的结束

代码语言:javascript
复制
B -> id · P

将是州q

代码语言:javascript
复制
B -> id · P
P -> · ( E )
P -> ·

其中goto(q, P)将指示向B -> id P ·的转换,goto(q,()将表示向P -> ( · E )的转换。goto on $)没有在该状态上定义,但action定义了;它将指示应该使用P ->规则减少P,然后使用goto(q, P)

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26518050

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档