高命中编译原理期末试题及答案.doc

上传人:h**** 文档编号:1231017 上传时间:2019-01-01 格式:DOC 页数:38 大小:1.42MB
下载 相关 举报
高命中编译原理期末试题及答案.doc_第1页
第1页 / 共38页
高命中编译原理期末试题及答案.doc_第2页
第2页 / 共38页
高命中编译原理期末试题及答案.doc_第3页
第3页 / 共38页
高命中编译原理期末试题及答案.doc_第4页
第4页 / 共38页
高命中编译原理期末试题及答案.doc_第5页
第5页 / 共38页
点击查看更多>>
资源描述

1、第 1 页共 6 页编译原理期末试题(一)一、是非题(请在括号内,正确的划,错误的划)(每个 2 分,共 20 分)1编译程序是对高级语言程序的解释执行。( )2一个有限状态自动机中,有且仅有一个唯一的终态。()3一个算符优先文法可能不存在算符优先函数与之对应。 ( )4语法分析时必须先消除文法中的左递归 。 ()5LR 分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错地点。 ()6逆波兰表示法表示表达式时无须使用括号。 ( )7静态数组的存储空间可以在编译时确定。 ()8进行代码优化时应着重考虑循环的代码优化,这对提高目标代码的效率将起更大作用。 ()9两个正规集相等的必要条件

2、是他们对应的正规式等价。 ( )10一个语义子程序描述了一个文法所对应的翻译工作。 ()二、选择题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)( 每个 4 分,共 40 分)1词法分析器的输出结果是_。A( ) 单词的种别编码 B( ) 单词在符号表中的位置 C( ) 单词的种别编码和自身值 D( ) 单词自身值2 正规式 M 1 和 M 2 等价是指_。 A( ) M1 和 M2 的状态数相等 B( ) M1 和 M2 的有向边条数相等C( ) M1 和 M2 所识别的语言集相等 D( ) M1 和 M2 状态数和有向边条数相等 3 文法 G:SxSx|y 所识别的语言是_。

3、A( ) xyx B( ) (xyx)* C( ) xnyxn(n0) D( ) x*yx* 4如果文法 G 是无二义的,则它的任何句子 _。A( ) 最左推导和最右推导对应的语法树必定相同 第 2 页共 6 页B( ) 最左推导和最右推导对应的语法树可能不同 C( ) 最左推导和最右推导必定相同 D( ) 可能存在两个不同的最左推导,但它们对应的语法树相同 5构造编译程序应掌握_。A( ) 源程序 B( ) 目标语言 C( ) 编译方法 D( ) 以上三项都是 6四元式之间的联系是通过_实现的。 A( ) 指示器 B( ) 临时变量 C( ) 符号表 D( ) 程序变量 7表达式(AB)(C

4、D) 的逆波兰表示为_。A. ( ) AB CD B( ) ABCD C( ) ABCD D( ) ABCD 8. 优化可生成_的目标代码。A( ) 运行时间较短 B( ) 占用存储空间较小C( ) 运行时间短但占用内存空间大 D( ) 运行时间短且占用存储空间小9下列_优化方法不是针对循环优化进行的。A. ( ) 强度削弱 B( ) 删除归纳变量 C( ) 删除多余运算 D( ) 代码外提10编译程序使用_区别标识符的作用域。 A. ( ) 说明标识符的过程或函数名B( ) 说明标识符的过程或函数的静态层次C( ) 说明标识符的过程或函数的动态层次 D. ( ) 标识符的行号三、填空题(每空

5、 1 分,共 10 分)1计算机执行用高级语言编写的程序主要有两种途径:_解释_和_编译_。 2扫描器是_词法分析器_,它接受输入的_源程序_,对源程序进行_词法分析_并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。3自上而下分析法采用_移进_、归约、错误处理、_接受_等四种操作。第 3 页共 6 页4一个 LR 分析器包括两部分:一个总控程序和 _一张分析表_。5后缀式 abc-/所代表的表达式是_a/(b-c)_。 6局部优化是在_基本块_范围内进行的一种优化。四、简答题(20 分)1. 简要说明语义分析的基本功能。答:语义分析的基本功能包括: 确定类型、类型检查、语义处理

6、和某些静态语义检 查。2. 考虑文法 GS: S (T) | a+S | a T T,S | S 消除文法的左递归及提取公共左因子。解:消除文法 GS的左递归: S(T) | a+S | a TST T,ST| 提取公共左因子: S(T) | aS S+S | TST T,ST| 3. 试为表达式 w+(a+b)*(c+d/(e-10)+8) 写出相应的逆波兰表示。解: w a b + c d e 10 - / + 8 + * +5. 已知文法 GS 为 S aSb|Sb|b ,试证明文法 GS 为二义文法。证明: 由文法 GS:SaSb|Sb|b,对句子 aabbbb 对应的两棵语法树为:第

7、 4 页共 6 页因此,文法 GS为二义文法。 五.计算题(10 分)已知文法 A-aAd|aAb| 判断该文法是否是 SLR(1) 文法,若是构造相应分析表,并对输入串 ab# 给出分析过程。解:增加一个非终结符 S/后,产生原文法的增广文法有: S-A A-aAd|aAb| 下面构造它的 LR(0)项目集规范族为: 第 5 页共 6 页从上表可看出,状态 I0 和 I2 存在移进-归约冲突,该文法不是 LR(0)文法。对于 I0 来说有:FOLLOW(A)a=b,d,#a=,所以在 I0 状态下面临输入符号为 a 时移进,为 b,d,#时归约,为其他时报错。对于 I2 来说有也有与 I0

8、完全相同的结论。这就是说,以上的移进 -归约冲突是可以解决的,因此该文法是 SLR(1)文法。 其 SLR(1)分析表为: 对输入串 ab#给出分析过程为: 第 6 页共 6 页编译原理期末试题(二)一、是非题:1.一个上下文无关文法的开始符,可以是终结符或非终结符。 ( )2.一个句型的直接短语是唯一的。 ( )3.已经证明文法的二义性是可判定的。 ( )4.每个基本块可用一个 DAG 表示。 ( )5.每个过程的活动记录的体积在编译时可静态确定。 ( )6.2 型文法一定是 3 型文法。 ( )7.一个句型一定句子。 ( )8.算符优先分析法每次都是对句柄进行归约。 X ( )9.采用三元

9、式实现三地址代码时,不利于对中间代码进行优化。 ( )10.编译过程中,语法分析器的任务是分析单词是怎样构成的。 ( )11.一个优先表一定存在相应的优先函数。 X ( )12.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 ( )13.递归下降分析法是一种自下而上分析法。 ( )14.并不是每个文法都能改写成 LL(1)文法。 ( )15.每个基本块只有一个入口和一个出口。 ( )16.一个 LL(1)文法一定是无二义的。 ( )17.逆波兰法表示的表达试亦称前缀式。 ( )18.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 ( )19.正规文法产生的语言都可以用上下文

10、无关文法来描述。 ( )20.一个优先表一定存在相应的优先函数。 ( )第 7 页共 6 页21.3 型文法一定是 2 型文法。 ( )22.如果一个文法存在某个句子对应两棵不同的语法树,则文法是二义性的。 ( )答案:1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11.12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22.二、填空题:2.编译过程可分为 ( 词法分析) , (语法分析) , (语义分析与中间代码生成 ) , (优化)和(目标代码生成 )五个阶段。3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是( 二义性的 ) 。

11、 4.从功能上说,程序语言的语句大体可分为( 执行性 )语句和(说明性 )语句两大类。5.语法分析器的输入是( 单词符号 ) ,其输出是( 语法单位 ) 。6.扫描器的任务是从( 源程序中 )中识别出一个个( 单词符号 ) 。7.符号表中的信息栏中登记了每个名字的有关的性质,如(类型、种属、所占单元大小、地址)等等。8.一个过程相应的 DISPLAY 表的内容为(现行活动记录地址和所有外层最新活动记录的地址)10.常用的两种动态存贮分配办法是(栈式)动态分配和(堆式)动态分配。11.一个名字的属性包括( 类型)和(作用域 )。12.常用的参数传递方式有(传地址) , (传值) , (传名)13

12、.根据优化所涉及的程序范围,可将优化分成为(局部优化) , (循环优化) , (全局优化)三个级别。14.语法分析的方法大致可分为两类,一类是( 自上而下 )分析法,另一类是( 自下而上 )分析法。15.预测分析程序是使用一张( 分析表 )和一个( 符号栈 )进行联合控制的。17.一张转换图只包含有限个状态,其中有一个被认为是(初)态;而且实际上至少要有一个(终 )态。19.语法分析是依据语言的(语法 )规则进行。中间代码产生是依据语言的(语义)规则进行的。21.一个文法 G,若它的预测分析表 M 不含多重定义,则该文法是(LL(1) 文法)文法。22.对于数据空间的存贮分配, FORTRAN

13、 采用( 静态策略, PASCAL 采用( 动态)策略。24.最右推导亦称为(规范推导) ,由此得到的句型称为(规范)句型。26.对于文法 G,仅含终结符号的句型称为 ( 句子 )。27.所谓自上而下分析法是指(从开始符号出发,向下推导,推出句子)29.局限于基本块范围的优化称( 局部优化 ) 。第 8 页共 6 页31.2 型文法又称为(上下文无关)文法;3 型文法又称为(正则 )文法。32.每条指令的执行代价定义为(指令访问主存次数加 1)33.算符优先分析法每次都是对(最左素短语)进行归约。四、简答题:1.写一个文法 G, 使其语言为 不以 0 开头的偶数集。2.已知文法 G(S)及相应

14、翻译方案SaAb print “1”Sa print “2”AAS print “3”Ac print “4”输入 acab, 输出是什么?3. 已知文法 G(S)SbAaA(B | aBAa)写出句子 b(aa)b 的规范归约过程。4. 考虑下面的程序:procedure p(x, y, z);beginy:=x+y;z:=z*z;endbeginA:=2;B:=A*2;P(A, A, B);Print A, Bend.试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 A, B 的值是什么? 5文法 G(S)SdABAaA| aBBb| 描述的语言是什么?6. 证明文法 G(S)

15、SSaS| 是二义性的。7. 已知文法 G(S)SBAABS| dBaA| bS | c的预测分析表如下第 9 页共 6 页a b c d #S SBA SBA SBAA ABS ABS ABS AdB BaA BbS Bc给出句子 adccd 的分析过程。8. 写一个文法 G, 使其语言为 L(G)=a lbmclanbn| l=0, m=1, n=2 9. 已知文法 G(S):Sa| (T)TT,S|S的优先关系表如下:关系 a ( ) ,a - - . .( ., .请计算出该优先关系表所对应的优先函数表。10. 何谓优化?按所涉及的程序范围可分为哪几级优化?11. 目标代码有哪几种形式

16、?生成目标代码时通常应考虑哪几个问题?12. 一字母表 =a, b,试写出 上所有以 a 为首的字组成的正规集相对应的正规式。13. 基本的优化方法有哪几种?14. 写一个文法 G, 使其语言为 L(G)=ab ncn| n015. 考虑下面的程序:procedure p(x, y, z);beginy:=y+z;z:=y*z+xend;begina:=2;b:=3;p(a+b, b, a);print aend.试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 a 的值是什么? 16.写出表达式 ab*(c-d)/e 的逆波兰式和三元序列。17.证明文法 G(A)AAA | (A

17、)| 是二义性的。18.令 =a,b,则正规式 a*b|b*a 表示的正规集是什么?19.何谓 DISPLAY 表?其作用是什么?20.考虑下面的程序:第 10 页共 6 页procedure p(x, y, z);beginy:=y+2;z:=z+x;endbegina:=5;b:=2;p(a+b, a-b, a);print aend.试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 a 的值是什么? 21.写一个文法 G, 使其语言为 L(G)=a nbncm| n0 为奇数, m0 为偶数22.写出表达式 a:=(b+c)*e+(b+c)/f 的逆波兰式和三元序列。23.一

18、个文法 G 别是 LL(1)文法的充要条件是什么?24.已知文法 GSSS*aF | aF | *aFF+aF | +a消除文法左递归和提公共左因子。25.符号表的作用是什么?符号表查找和整理技术有哪几种?答案:1.所求文法是 GS:SAB |B A0AAD |CB2 |4 |6 |8C1 |3 |5 |7 |9 |BD0 |C2.输出是 42313.句子 b(aa)b 的规范归约过程:步骤 符号栈 输入串 动作0 # b(aa)b# 预备1 #b (aa)b# 移进2 #b( aa)b# 移进3 #b(a a)b# 移进4 #b(A a)b# 归约5 #b(Ma )b# 移进6 #b(Ma) b# 移进7 #b(B b# 归约8 #bA b# 归约9 #bAb # 移进10 #S # 接受4.传地址 A=6, B=16传值 A=2, B=45.L(G)=danbm |n0, m0

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 试题真题

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。