第一范文网 - 专业文章范例文档资料分享平台

最新编译原理期末考试试卷及答案

来源:用户分享 时间:2025/5/31 9:22:32 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

read c B1 A=0 B=1 B2 L4: A=A+B If B>C goto L2 (OR B4) B3 B=B+1 Goto L4 (OR B2) B4 L2: write A

8. (1)共4分,错一项扣1分,扣完为止 (2)共4分,错一项扣1分,扣完为止 t1=b*c t2=b*d t3=t1-t2 t4=i+1 (or t4=i) b[t4]=t3

一、判断题:

1.一个上下文无关文法的开始符,可以是终结符或非终结符. ( ) 2.一个句型的直接短语是唯一的. ( ) 3.已经证明文法的二义性是可判定的. 4.每个基本块可用一个DAG表示. 5.每个过程的活动记录的体积在编译时可静态确定. 6.2型文法一定是3型文法. 7.一个句型一定句子. ( ) 8.算符优先分析法每次都是对句柄进行归约. ( ) 9.采用三元式实现三地址代码时,不利于对中间代码进行优化. 10.编译过程中,语法分析器的任务是分析单词是怎样构成的. ( ) 11.一个优先表一定存在相应的优先函数. ( ) 12.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题. ( ) 13.递归下降分析法是一种自下而上分析法. ( ) 14.并不是每个文法都能改写成LL(1)文法. ( ) 15.每个基本块只有一个入口和一个出口. ( ) 16.一个LL(1)文法一定是无二义的. ( ) 17.逆波兰法表示的表达试亦称前缀式. ( ) 18.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题. ( ) 19.正规文法产生的语言都可以用上下文无关文法来描述. ( ) 20.一个优先表一定存在相应的优先函数. ( ) 21.3型文法一定是2型文法. ( ) 22.如果一个文法存在某个句子对应两棵不同的语法树,则文法是二义性的. ( ) 二、填空题:

1.( )称为规范推导.

11 / 15

) ) ) ) ) (((((

2.编译过程可分为 ( ) ,( ),( ),( )和( )五个阶段. 3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是( ). 4.从功能上说,程序语言的语句大体可分为( )语句和( )语句两大类. 5.语法分析器的输入是( ),其输出是( ). 6.扫描器的任务是从( )中识别出一个个( ).

7.符号表中的信息栏中登记了每个名字的有关的性质,如( )等等. 8.一个过程相应的DISPLAY表的内容为( ). 9.一个句型的最左直接短语称为句型的( ).

10.常用的两种动态存贮分配办法是( )动态分配和( )动态分配. 11.一个名字的属性包括( )和( ). 12.常用的参数传递方式有( ),( )和( ). 13.根据优化所涉及的程序范围,可将优化分成为( ),( )和( )三个级别. 14.语法分析的方法大致可分为两类,一类是( )分析法,另一类是( )分析法. 15.预测分析程序是使用一张( )和一个( )进行联合控制的. 16.常用的参数传递方式有( ),( )和( ).

17.一张转换图只包含有限个状态,其中有一个被认为是( )态;而且实际上至少要有一个( )态. 18.根据优化所涉及的程序范围,可将优化分成为( ),( )和( )三个级别. 19.语法分析是依据语言的( )规则进行.中间代码产生是依据语言的( )规则进行的. 20.一个句型的最左直接短语称为句型的( ).

21.一个文法G,若它的预测分析表M不含多重定义,则该文法是( )文法.

22.对于数据空间的存贮分配, FORTRAN采用( )策略, PASCAL采用( )策略. 23.如果一个文法存在某个句子对应两棵不同的语法树, 则称这个文法是( ). 24.最右推导亦称为( ),由此得到的句型称为( )句型.

25.语法分析的方法大致可分为两类,一类是( )分析法,另一类是( )分析法. 26.对于文法G,仅含终结符号的句型称为 ( ).

27.所谓自上而下分析法是指( ). 28.语法分析器的输入是( ),其输出是( ). 29.局限于基本块范围的优化称( ).

30.预测分析程序是使用一张( )和一个( )进行联合控制的. 31.2型文法又称为( )文法;3型文法又称为( )文法.

32.每条指令的执行代价定义为( ). 33.算符优先分析法每次都是对( )进行归约. 三、名词解释题:

1.局部优化 2.二义性文法 3.DISPLAY表 4.词法分析器 5.最左推导 6.语法 7.文法 8.基本块

9.语法制导翻译 10.短语 11.待用信息 12.规范句型 13.扫描器 14.超前搜索 15.句柄

16.语法制导翻译 17.规范句型 18.素短语 19.语法

12 / 15

20.待用信息 21.语义 四、简答题:

1.写一个文法G, 使其语言为 不以0开头的偶数集. 2.已知文法G(S)及相应翻译方案

S→aAb {print “1”} S→a {print “2”} A→AS {print “3”} A→c {print “4”} 输入acab, 输出是什么? 3. 已知文法G(S)

S→bAa

A→(B | a B→Aa)

写出句子b(aa)b的规范归约过程. 4. 考虑下面的程序:

procedure p(x, y, z); begin y:=x+y; z:=z*z; end begin

A:=2; B:=A*2; P(A, A, B); Print A, B end.

试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 A, B的值是什么? 5.文法G(S) S→dAB A→aA| a B→Bb| ε

描述的语言是什么? 6.证明文法G(S) S→SaS| ε 是二义性的. 7.已知文法G(S) S→BA A→BS| d

B→aA| bS | c 的预测分析表如下

a b c d # S S→BA S→BA S→BA A A→BS A→BS A→BS A→d B B→aA B→bS B→c

给出句子 adccd 的分析过程.

lmlnn

8.写一个文法G, 使其语言为 L(G)={abcab| l>=0, m>=1, n>=2} 9.已知文法G(S): S→a| (T)

13 / 15

T→T,S|S

的优先关系表如下:

关系 a ( ) , a .> .> ( <. <. =. <. ) .> .> , <. <. .> .> 请计算出该优先关系表所对应的优先函数表. 10.何谓优化?按所涉及的程序范围可分为哪几级优化?

11.目标代码有哪几种形式?生成目标代码时通常应考虑哪几个问题?

12.一字母表Σ={a, b},试写出Σ上所有以a为首的字组成的正规集相对应的正规式. 13.基本的优化方法有哪几种?

nn

14.写一个文法G, 使其语言为 L(G)={abc| n≥0} 15.考虑下面的程序:

procedure p(x, y, z); begin y:=y+z; z:=y*z+x end; begin a:=2; b:=3;

p(a+b, b, a); print a end.

试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 a的值是什么? 16.写出表达式a+b*(c-d)/e的逆波兰式和三元序列. 17.证明文法G(A) A→AA | (A)| ε 是二义性的.

**

18.令Σ={a,b},则正规式ab|ba表示的正规集是什么? 19.何谓DISPLAY表?其作用是什么? 20.考虑下面的程序: …

procedure p(x, y, z); begin y:=y+2; z:=z+x; end begin

a:=5; b:=2;

p(a+b, a-b, a); print a end.

试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 a的值是什么?

nnm

21.写一个文法G, 使其语言为 L(G)={abc| n>0为奇数, m>0为偶数} 22.写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列. 23.一个文法G别是LL(1)文法的充要条件是什么? 24.已知文法G[S]

14 / 15

S→S*aF | aF | *aF F→+aF | +a

消除文法左递归和提公共左因子.

25.符号表的作用是什么?符号表查找和整理技术有哪几种? 五、计算题: 1.设文法G(S):

S→^ | a | (T) T→T,S | S

⑴ 消除左递归;

⑵ 构造相应的FIRST和FOLLOW集合; ⑶ 构造预测分析表 2.语句 if E then S

(1) 改写文法,使之适合语法制导翻译; (2) 写出改写后产生式的语义动作. 3.设文法G(S): S→(T) | a T→T+S | S

(1)计算FIRSTVT 和LASTVT; (2)构造优先关系表. 4.设某语言的for语句的形式为

for i:=E(1) to E(2)

do S 其语义解释为

i:=E(1)

LIMIT:=E(2)

again: if i<=LIMIT then

Begin S;

i:=i+1 goto again End;

(1)写出适合语法制导翻译的产生式; (2)写出每个产生式对应的语义动作. 5.把语句

while a<10 do

15 / 15

搜索更多关于: 最新编译原理期末考试试卷及答案 的文档
最新编译原理期末考试试卷及答案.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c1yu9r13rvu3bj0w6iip07zlrl1bkfq0132q_3.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top