编译原理 消除文法二义性

huoyunka 2008-11-05 02:48:44
正在些语法分析程序,请问怎样用程序判断文法是不是具有二义性,并用程序消除二义性.
如果有例子最好,不然说说思路也可以,先谢谢了
...全文
2108 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
太乙 2008-11-09
  • 打赏
  • 举报
回复
upup~~~
zsl6658 2008-11-09
  • 打赏
  • 举报
回复
jf
lzh9955 2008-11-09
  • 打赏
  • 举报
回复
期待中!!!
yzfyzyl 2008-11-06
  • 打赏
  • 举报
回复
这个得在语法设计时就要考虑了,即使是C/C++也存在二义性、不确定性的语法
对于这种情况,各编译器考虑的不同的方案,主要还是看你如何进行文法分析
你可以选一种方便分析的一种去做。

于是,要判断二义性的存在,可以尝试使用不同的优先顺序解释
假如解释出现歧义,那么一定存在二义性的语法(如经典的++运算)

要消除二义性,最简单可行的就是定义优先级,不过不一定适合所有情况


飞燕算法群:46520219
yshuise 2008-11-06
  • 打赏
  • 举报
回复
编译原理对此有详细解说:
第一,就近结合原则。
第二,优先级结合原则。
第三,消除左递归(变成有递归)。
第四:提取公因式。
stuarts740 2008-11-06
  • 打赏
  • 举报
回复
学习,帮顶一下
Longinc 2008-11-05
  • 打赏
  • 举报
回复
友情帮顶

64,282

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧