最左推导和最右推导,语法树,二义性文法

※最左推导和最右推导

(每一步替换最左边的非终结符/每一步替换最右边的非终结符),最右推导称为规范推导。最右推导对应于最左规约(规范规约)

例:

文法:

S--->AB

A--->a|t

B---->+CD

C--->a

D---->a

最右推导:

S--->AB---->A+CD--->A+Ca---->A+aa----->a+aa

最左推导:

S---->AB----->aB--->a+CD--->a+aD----->a+aa



※语法树:

文法:

最左推导和最右推导,语法树,二义性文法 - 小镜子~ - 菜园子
 

相应的语法树:

最左推导和最右推导,语法树,二义性文法 - 小镜子~ - 菜园子
 

(这是最右推导的语法树)



※文法的二义性:

给定一个文法G,如果LG)中存在一个具有两棵或两棵以上分析树的句子, 我们就称该文法为二义性的,G也叫二义性文法。

对于以下文法:

最左推导和最右推导,语法树,二义性文法 - 小镜子~ - 菜园子
 

对于id+id*id的串,有两个分析树与之对应

最左推导和最右推导,语法树,二义性文法 - 小镜子~ - 菜园子
 

造成二义性的原因是:文法中没有体现出结合率和优先级

  • 40
    点赞
  • 116
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值