编译原理精品课.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一、简述编译程序的功能,并解释编译程序和解释程序的区别。(8分)。 编译程序的功能:编译程序的功能是把高级语言写成的程序转换成汇编语言程序或机器语言程序。 编译程序和解释程序的区别:在计算机上执行一个高级语言程序,编译程序是首先通过编译程序把源程序翻译成机器语言程序,然后执行目标程序;解释程序是采用边翻译边执行的解释执行方式来执行高级语言程序。 二、将下列ε-自动机转化为非ε-自动机。(10分) 解: 三、化简下列自动机。(12分) 解: 化为确定自动机: 2和4等价,3和(4,5)等价 五、已知文法G[Z]:Z→bMb M→a|(L L→Ma) (1)?试写出文法G的LL矩阵。 (2) 试写出b(aa)b的LL分析过程。(15分) 解: select(Z→bMb)={b} select(M→a|(L)={a,(} select(L→Ma))=first(M)={a,(} 六、设有文法定义:实型变量说明→real标识符表 标识符表→标识符表,i 标识符表→i 将该文法缩写后并拓广为G[S’]如下: 1. S’→ S 2. S→ r D 3. D→ D , i 4. D→ i 试判别G[S’]文法为SLR(1)文法,并写出该文法的SLR(1)矩阵。(15分) 解: follow(S)=follow(S’)={#} follow(S)∩{,}=φ 满足上述条件则可利用SLR(1)方法。 转化情况如下: 七、设有PASCAL过程说明段 PROCEDURE P(VAR X:real; Y:boolean); CONST pai=3.14; TYPE arr=ARRAY[1…10] OF integer; VAR m:integer; a:arr; BEGIN………………END 写出每个标识符的语义字。(10分) 解: 八、试写出表达式a*(b+c)的逆波兰式(要求写出详细分析过程)。(10分) 解: 九、设有语句列 X:=X*Y+Z; Y:=X*Y+Z; Z:=X*Y-Z 试写出优化前和优化后的四元式中间代码(要求用值编码法完成优化过程)。(10分) 优化前 编码 优化后 1. (*, X, Y, T1 ) (1, 2, 3) (*, X, Y, T1) 2. (+, T1, Z, T2 ) (3, 4, 5) (+, T1, Z, T2) 3. (:=, T2, -, X ) (5, 5) (:=, T2, -, X) 4. (*, X, Y, T3 ) (5, 2, 6) ( *, X, Y, T3) 5. (+, T3, Z, T4 ) (6, 4, 7) ( +, T3, Z, T4) 6. (:=, T4, -, Y ) (7, 7) (:=, T4, -, Y) 7. (*, X, Y, T5 ) (5, 7, 8) ( *, X, Y, T5) 8. (-, T5, Z, T6 ) (8, 4, 9) ( -, T5, Z, T6) 9. (:=, T6, -, Z ) (9, 9) (:=, T6, -, Z) 例1:记录类型RECORD u:integer; a:ARRAY[1…10] OF boolean; r:RECORD x,y:real END END 则表示如下图所示。 **记录类型 Array[1...10] of record d:ARRAY[1…100] OF integer; f:RECORD m,n:real END END 则表示如下图所示。 例子2:设有PASCAL过程说明段: PROCEDURE p(VAR x:real; y:boolean); CONST pai=3.14; TYPE arr=ARRAY[1…10] OF integer; VAR m:integer; a:arr; FUNCTION f(Z:real;FUNCTION G(U,W: real):real;K:

文档评论(0)

wuailuo + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档