编译原理期末试题

上传人:wt****50 文档编号:34544728 上传时间:2018-02-25 格式:DOC 页数:14 大小:240KB
返回 下载 相关 举报
编译原理期末试题_第1页
第1页 / 共14页
编译原理期末试题_第2页
第2页 / 共14页
编译原理期末试题_第3页
第3页 / 共14页
编译原理期末试题_第4页
第4页 / 共14页
编译原理期末试题_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《编译原理期末试题》由会员分享,可在线阅读,更多相关《编译原理期末试题(14页珍藏版)》请在金锄头文库上搜索。

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

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

5、 标识符的行号三、填空题(每空 1 分,共 101.优化可生成运行时间短且占用存储空间小的目标代码2.LR 分析法解决“移进-规约”冲突时,右结合意味着建立联系实行移进3.若 B 为非终结符,则 Aa.Bb 为待约项目4.在目标代码生成阶段,符号表用于数据存储分配的依据5.四元式之间的联系是通过临时变量实现的1计算机执行用高级语言编写的程序主要有两种途径:_解释_和_编译_。 2扫描器是_词法分析器_,它接受输入的_源程序_,对源程序进行_词法分析_并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。3自上而下分析法采用_移进_、归约、错误处理、_接受_等四种操作。4一个 LR 分

6、析器包括两部分:一个总控程序和 _一张分析表_。5后缀式 abc-/所代表的表达式是_a/(b-c)_。 6局部优化是在_基本块_范围内进行的一种优化。三、对于文法 G(E): (8 分) ET|E+TTF|T*FF(E)|i1. 写出句型 T*F+i1*i2 的最右推导并画出语法树。2. 写出上述句型的短语,直接短语、句柄、素短语和最左素短语答:1.E = E+T = E+T*F = E+T*i2 = E+F*i2 = E+i1*i2 = T*F +i1*i2 2.短语:T*F+i1*i2, T*F, i1*i2, i1, i2直接短语:T*F, i1, i2 句柄:T*F素短语:T*F,

7、i1, i2最左素短语:T*F 第 4 页共 6 页3. 试为表达式 w+(a+b)*(c+d/(e-10)+8) 写出相应的逆波兰表示。解: w a b + c d e 10 - / + 8 + * +编译原理期末试题(二)一、是非题:1.一个上下文无关文法的开始符,可以是终结符或非终结符。 ( )2.一个句型的直接短语是唯一的。 ( )3.已经证明文法的二义性是可判定的。 ( )4.每个基本块可用一个 DAG 表示。 ( )5.每个过程的活动记录的体积在编译时可静态确定。 ( )6.2 型文法一定是 3 型文法。 ( )7.一个句型一定句子。 ( )8.算符优先分析法每次都是对句柄进行归约

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

9、 ( )19.正规文法产生的语言都可以用上下文无关文法来描述。 ( )20.一个优先表一定存在相应的优先函数。 ( )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.如果一个文法存在某个句子对应两棵不同的语法树,则称这个

10、文法是( 二义性的 ) 。 5.语法分析器的输入是( 单词符号 ) ,其输出是( 语法单位 ) 。6.扫描器的任务是从( 源程序中 )中识别出一个个( 单词符号 ) 。13.根据优化所涉及的程序范围,可将优化分成为(局部优化) , (循环优化) , (全局优化)三个级别。14.语法分析的方法大致可分为两类,一类是( 自上而下 )分析法,另一类是( 自下而上 )分析法。15.预测分析程序是使用一张( 分析表 )和一个( 符号栈 )进行联合控制的。17.一张转换图只包含有限个状态,其中有一个被认为是(初)态;而且实际上至少要有一个(终 )态。19.语法分析是依据语言的(语法 )规则进行。中间代码产

11、生是依据语言的(语义)规则进行的。24.最右推导亦称为(规范推导) ,由此得到的句型称为(规范)句型。29.局限于基本块范围的优化称( 局部优化 ) 。31.2 型文法又称为(上下文无关)文法;3 型文法又称为(正则 )文法。33.算符优先分析法每次都是对(最左素短语)进行归约。16.写出表达式 ab*(c-d)/e 的逆波兰式和三元序列。16.逆波兰式: abcd-*e/+三元序列: op arg1 arg2(1) - c d(2) * b (1)(3) / (2) e(4) + a (3)五、计算题:四、设文法 G(S):(12 分)(|*)BA|Si1构造各非终结符的 FIRSTVT 和 LASTVT 集合;2构造优先关系表和优先函数。(12 分)答:(6 分)FIRSTVT(S)= i,+ ,) ,( FIRSTVT(A)= +,),( FIRSTVT(B)= ),( 第 6 页共 6 页LASTVT(S)= i,+,*,( LASTVT(A)= +,*,( LASTVT(B)= *,( 优先关系表: (3 分)i + ( ) *i ( )

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

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号