首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将模糊CFG转换为无歧义CFG。

将模糊CFG转换为无歧义CFG。
EN

Stack Overflow用户
提问于 2014-03-23 15:00:38
回答 1查看 861关注 0票数 1

我有语法:

代码语言:javascript
复制
S -> aSb | bSa | SS | epsilon

我想要生成一个明确的版本。

我尝试了分层,但只做到了这一点,这并不是明确的,我不相信,因为规则A -> aC和A -> AA都可以用于一些输入:

代码语言:javascript
复制
S -> A | epsilon

A -> aC | bD | AA

C -> Cb | b

D -> Da | a
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-03-23 15:12:53

代码语言:javascript
复制
S  -> aSb | bSa | SS | ϵ

如果我在这里没有完全错,这里唯一的问题是S的左递归,所以如果删除它,您应该很好:

代码语言:javascript
复制
S  -> S' S'
S' -> aSb | bSa | ϵ

这也应消除歧义。

另一种解决办法可以是:

代码语言:javascript
复制
S  -> aSbS | bSaS | ϵ
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22592547

复制
相关文章

相似问题

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