- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理(龙书)习题(5,6,7,8)章;5.2.4 这个文法生成了含“小数点”的二进制:
设计一个L属性的SDD来计算S.val,即输入串的十进制数值。比如,串101.11应该被翻译为十进制数5.635。提示:使用一个继承属性L.side来指明一个二进制位在小数点的哪一边。;为了求小数部分的值,引入L的综合属性b记录2的L
的位数次幂值(2 length of L)
S ? L1.L2 S.val = L1.val +L2.val / L2.b;
S ? L S.val = L.val;
L ? L1 B L.val = L1.val *2 + B.val;
L.b = L1.b*2;
L ? B L.val = B.val; L.b = 2;
B ? 0 B.val = 0;
B ? 1 B.val = 1;;5.3.1 下面是涉及运算符+和整数或浮点运算分量的表达式的文法。区分浮点数的方法是看它有无小数点。
1)给出一个SDD来确定每个项T和表达式E的类型。
2)扩展(1)中得到的SDD,使得它可以把表达式转换成为后缀表达式。使用一个单目运算符intToFloat把一个整数转换为相等的浮点数。;(2)设code 为综合属性,代表各非终结符的代码属性
type为综合属性,代表各非终结符的类型属性
inttoreal把整型值转换为相等的实型值
vtochar将数值转换为字符串 ;5.3.3 给出一个SDD对x*(3*x+x*x)这样的表达式求微分。表达式中涉及运算符+和*,变量x和常量。假设不进行任何简化,也就是说,比如3*x将被翻译为3*1+0*x。
exp 为原表达式的字符串,s 为求导后的字符串。
|| 为串联接符。;5.4.3 下面的SDT计算了一个由0和1组成的串的值。它把输入的符号串当作按照正二进制数来解释。
改写这个SDT,使得基础文法不再是左递归的,但仍然可以计算出整个输入串的相同的B.val的值。
;非终结符D的综合属性b表示二进制数的位数,val表
示对应的十进制数的数值。消除左递归后如下:;第6章 中间代码生成;6.2.1 将算术表达式 a+-(b+c) 翻译成
1)抽象语法树
2)四元式序列
3)三元式序列
4)间接三元式序列;1)抽象语法树:;2)四元式序列:
3)三元式序列:
4)间接三元式序列:
;6.4.1 向图6-19的翻译方案中加入对应于下列产生式的规则:
1)
2);6.4.2 使用图6-20中的增量式翻译方案重复练习6.4.1;;6.6.1 在图6-30的语法制导定义中添加处理下列控制流构造的规则:
1)一个repeat语句,repeat S while B
2)一个for循环语句,for (S1 ; B ; S2) S3;S--for ( S1; B; S2 ) S3
S1.next=newlabel()
B.true=newlabel()
begin=newlabel()
B.fale=S.next
S2.next =S1.next
S3.next=begin
S.code=S1.code||label(S1.next)||
B.code||label(begin)||
S2.code||
gen(goto S1.next)||
label(B.true)||S3.code||
gen(goto begin);6.7.7 使用图6-37中的翻译方案翻译下列表达式。给出每个子表达式的truelist和falselist。你可以假设第一条被生成的指令的地址是100。
1)a==b(c==d||e==f);100: if a==b goto 102
101: goto __
102: if c==d goto __
103: goto 104
104: if e==f goto __
105: goto __;第7章 运行时环境;第1个f(1)调用即将返回;7.2.5 在一个通过引用传递参数的语言中,有一个函数f(x,y)完成下面的计算:
x = x + 1; y = y + 2; return x + y;
如果将a赋值为3,然后调用f(a,a),那么返回值是什么?
函数返回值为:12
此时a的值为:6;第8章 代码生成;8.2.2 假设a和b是元素为4字节值的数组,为下面的三地址语句序列生成代码。
2)三个语句序列
x = a[i]
您可能关注的文档
最近下载
- 23G409 先张法预应力混凝土管桩 conv.docx VIP
- WIP.010-SIE EBS标准化操作手册- 按订单装配 (ATO) 制造.pdf VIP
- 2025入团考试100题题库(含答案).pdf VIP
- SG111-1~2:建筑结构加固施工图设计表示方法建筑结构加固施工图设计深度图样(2008合订本).docx VIP
- 最新水利工程维护养护定额标准.docx VIP
- IQ-FMECA软件操作手册—功能与使用.pdf VIP
- WIP.006-SIE EBS标准化操作手册-资源事务处理.pdf VIP
- WIP.009-SIE EBS标准化操作手册-离散任务状态.pdf VIP
- 消防维保质量保证体系.docx VIP
- 2024年四川成都交通投资集团有限公司招聘笔试真题.docx VIP
文档评论(0)