编译原理-语法制导翻译 课后习题+笔记

语法制导翻译

来源:龙书(厚),南大课后作业

p198 5.1.2

注:对以n为结尾标记的表达式求值
在这里插入图片描述

Answer

E,T:表达式(也可看做一个数)
E’:后+一个表达式
T’:后*一个表达式
F:因子,可以是一个数或一个带括号式子

产生式语法规则
1)L -> EnL.val = E.val
2)E -> TE'E'.inh = T.val
E.val = E'.syn
3)E' -> +TE_1'E_1'.inh = E'.inh + T.val
E'.syn = E_1'.syn
4)E' -> εE'.syn = E'.inh
5)T -> FT'T'.inh = F.val
T.val = T'.syn
6)T' -> *FT_1'T_1'.inh = T'.inh * F.val
T'.syn = T_1'.syn
7)T' -> εT'.syn = T'.inh
8)F -> (E)F.val = E.val
9)F -> digitF.val = digit.lexval

知识点
  • SDD

p202 5.2.2

在这里插入图片描述
对于图 5-8 中的 SDD,给出下列表达式对应的注释语法分析树:

  1. int a, b , c
Answer

参考龙书p202
注释语法分析树:
在这里插入图片描述

注释语法分析树的依赖图:
在这里插入图片描述

知识点
  • 注释语法分析树与依赖图

p216 5.4.3

在这里插入图片描述

Answer

提取左公因子

B -> B1 A {B.val = 2 * B1.val + A.val}
   | 1 {B.val = 1}
A -> 0 {A.val = 0} 
       | 1 {A.val = 1}

消除左递归后得

B -> 1 {C.i = 1} C{B.val=C.val}
C -> A {C1.i = 2 * C.i + A.val} C1 {C.val = C1.val}
   | ε {C.val = C.i}
A -> 0 {A.val = 0} 
       | 1 {A.val = 1}

val为综合属性,i为继承属性

知识点
  • 2
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值