编译原理四种lr文法的判断(LR(0),SLR(1),LALR(1),LR(1))

关系:LR(0)<SLR(1)<LALR(1)<LR(1)
如果前边一个文法判断是后边都是
比如:是LR(0)也是 SLR(1)也是 LALR(1)也是LR(1)
不是LR(0),但是是SLR(1)就也是LALR(1)也是LR(1)
以此类推

1.判断LR(0)文法:

看项目中是否有归约-归约和移进-归约冲突。
如果无冲突则是LR(0)文法(如果是LR(0)文法则四种都是);如果有冲突则不是LR(0)文法。(就要向下判断)

2.判断SLR(1)文法:

a:DFA中存在冲突项目(归约-归约,归约-移进)
b:{a1,a2,…,an},FOLLOW(B1),FOLLOW(B2)两两互不相交,(交集=空集)时是SLR(1)项目。
【也就是说,同时满足两个条件才是SLR(1)文法】

若不是再向下判断。

3.判断LR(1)文法:

构造带向前搜索符的DFA,无归约-归约冲突则是LR(1)文法。

【此处意思是如果有向前搜索符还有冲突的话就不是LR(1)文法,就要再向下判断】

4.判断LALR(1)文法:

合并同心集后无(归约-归约)冲突(在之前的基础上)
(核相同,向前搜索符不同)

(B->a,a
B->a,a|b
同心集)

  • 68
    点赞
  • 389
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值