当前位置:文档之家› 编译原理期末考试试卷与答案

编译原理期末考试试卷与答案

得分一.填空题(每空 2 分,共20 分)

1. 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静

态存储分配方案和动态存储分配方案,而后者又分为( 1)和( 2)。

2.规范规约是最( 3)规约。

3.编译程序的工作过程一般划分为 5 个阶段:词法分析、( 4)、语义分析与中间代码生成,代码优化及

( 5)。另外还有( 6)和出错处理。

4.表达式 x+y*z/(a+b) 的后缀式为(7)。

5.文法符号的属性有综合属性和( 8)。

6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..20]某个元素a[i , j]的地址计算公式为( 9)。

7.局部优化是局限于一个(10)范围内的一种优化。

得分

二.选择题(1-6 为单选题, 7-8 为多选题,每问 2 分,共 20 分)

1. 一个上下文无关文法G包括四个组成部分:一组终结符,一组非终结符,一个(),以及一组()。

A.字符串B.产生式C.开始符号D.文法

2. 程序的基本块是指()。

A.一个子程序B.一个仅有一个入口和一个出口的语句

C.一个没有嵌套的程序段 D .一组顺序执行的程序段,仅有一个入口和一个出口

3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于()分析方法。

A.自左向右B.自顶向下C.自底向上D.自右向左

4.在通常的语法分析方法中,()特别适用于表达式的分析。

A.算符优先分析法B. LR 分析法

C.递归下降分析法D. LL (1)分析法

5.经过编译所得到的目标程序是()。

A.四元式序列B.间接三元式序列

C.二元式序列D.机器语言程序或汇编语言程序

6.一个文法所描述的语言是();描述一个语言的文法是()。

A.唯一的B.不唯一的C.可能唯一,也可能不唯一

7.如果在文法G中存在一个句子,当其满足下列条件()之一时,则称该文法是二义文法。

A.其最左推导和最右推导相同B.该句子有两个不同的最左推导

C.该句子有两个不同的最右推导 D .该句子有两棵不同的语法树

E.该句子对应的语法树唯一

8.下面()语法制导翻译中,采用拉链—回填技术。

A. 赋值语句

B.布尔表达式的计算

C.条件语句

D.循环语句

得分

三.解答题(共60分)

1.(共 15 分)已知文法G[E]:

E→ ETE|(E) |i

T→*|+

( 1)将文法G改造成LL(1)文法;(5分)

( 2)构造文法G中每个非终结符的FIRST 集合及 FOLLOW集合;( 5 分)

( 3)构造LL(1)分析表。(5分)

2.(共 12 分)给定文法G[S] : S→ S(S)| ε

( 1)给出句子 (()())()()的规范推导过程;(4分)

(2)指出每步推导所得句型的句柄;( 4 分)

(3)画出该句子的语法推导树。( 4 分)

3.(共 8 分)在一个移入 - 规约分析过程中采用以下的语法制导翻译模式,在按一个产生式规约时,立即

执行括号中的动作。

A→ aB{print“0”; }

A→ c{print“1”; }

B→ Ab{print“2”; }

( 1)当分析器的输入为aacbb 时,打印的字符串是什么?( 3 分)

( 2)写出分析过程。(5分)

4.( 10 分)翻译循环语句while (ad) then x:=y+z。要求:给出加注释的分析树及四元式序列。

参考以下部分翻译模式:

(1) S→ if E then M S1{backpatch(E.truelist,M.quad);

S.nextlist:=merge(E.falselist,S 1 .nextlist)}

(2)S→ while M 1 E do M 2 S 1 {backpatch(S1.nextlist,M1, .quad);

backpatch(E.truelist,M2, .quad);

S.nextlist:=E.falselist

emit ( ‘ j,-,-,’ M1 .quad)}

(3)S→ A{S.nextlist:=makelist()}

(4)L→ S{L.nextlist:=S.nextlist}

(5)M→ε{M.quad:=nextquad}

(6)E→ id1 relop id2{E.truelist:=makelist(nextquad);

e.falselist:=makelist(nextquad+1);

emit(‘ j ’ relop.op,‘, ’ id 1.place ‘ , ’ id 2 .place ‘ , ’‘ 0’ );

emit(‘ j,-,-,0 ’ )}

(7)S→ L:=E{emit(:=,E.place,-,L.place)}

(8)E→E+E{E.place:=newtemp;

12

emit(+,E.place,E

2.place,E.place,)}

1

5.(共 15 分)设有表格构造文法G[S] :

S→ a| ∧ |(T)

T→ T,S|S

(1)计算文法 G[S] 的 FIRSTVT集和 LASTVT集。( 5 分)

(2)构造 G[S] 的优先关系表,并判断 G[S] 是否为算符优先文法。( 5 分)

(3)计算 G[S] 的优先函数。( 5 分)

得分

二.单项选择题(每题 2 分,共 10 分)

1.设有文法G[I] : I → I1|I0|Ia|Ic|a|b|c

下列符号串中是该文法句子的有()。

① ab0② a0c01③ aaa④ bc10

可选项有:

A.①B.②③④C.③④D.①②③④

2. 程序的基本块是指()。

A.一个子程序B.一个仅有一个入口和一个出口的语句

C.一个没有嵌套的程序段 D .一组顺序执行的程序段,仅有一个入口和一个出口

3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于()分析方法。

A.自左向右 B .自顶向下C.自底向上D.自右向左

4.经过编译所得到的目标程序是()。

A.四元式序列B.间接三元式序列

C.二元式序列D.机器语言程序或汇编语言程序

5.运行阶段的存储组织与管理的目的是()。

① 提高编译程序的运行速度② 节省编译程序的存储空间

③ 提高目标程序的运行速度④ 为运行阶段的存储分配做准备

可选项有:

A. ①②

B.②③

C.③④

D.④②

得分 2.(10 分)已知文法G[S]:

S→ aBc|bAB

A→ aAb|b

B→b| ε

( 4)构造其LL(1)分析表;

( 5)判断符号串baabbb 是否为该文法的句子(写出含有符号栈、输入串和规则的分析过程)。

3.(10 分 ) 已知文法 G为:

E→ E+T|T

T→ T*P|P

P→ i

(1)构造该文法的优先关系表(不考虑语句括号#),并指出此文法是否为算符优先文法。

(2)构造文法 G的优先函数表。

4.( 8 分)在一个移入 - 规约分析过程中采用以下的语法制导翻译模式,在按一个产生式规约时,立即执

行括号中的动作。

S→ bAb{print“ 1”}

A→ (B{print“2”}

A→ a{print“ 3”}

B→ Aa){print“ 4”}

(3)当输入序列为 b(((aa)a)a)b 时,打印的字符串是什么?

(4)写出移入 - 规约分析过程。

5.(12分)翻译循环语句 while (x>y) do if (a=b) then x:=2*y+a。要求:给出加注释的分析树、三地址码序列及相应的四元式序列。

参考以下部分翻译模式:

(1)S→ if E then M S1{backpatch(E.truelist,M.quad);

S.nextlist:=merge(E.falselist,S1.nextlist)}

(2)S→ while M 1 E do M 2 S 1 {backpatch(S1.nextlist,M1, .quad);

backpatch(E.truelist,M2, .quad);

S.nextlist:=E.falselist

emit ( ‘ j,-,-,’ M1 .quad)}

(3)S→ A{S.nextlist:=makelist()}

(4)L→ S{L.nextlist:=S.nextlist}

(5)M→ε{M.quad:=nextquad}

(6)E→ id 1 relop id2{E.truelist:=makelist(nextquad);

e.falselist:=makelist(nextquad+1);

emit(‘ j ’ relop.op,‘, ’ id 1.place ‘ , ’ id 2 .place ‘ , ’‘ 0’ );

emit(‘ j,-,-,0 ’ )}

(7)S→ L:=E{emit(:=,E.place,-,L.place)}

(8)E→E+E{E.place:=newtemp;

12

emit(+,E.place,E

2.place,E.place,)}

1

6. (8 分 ) Generate assembly code for the following sequence assuming that x,y and z are in memory

locations(noticing only two registers R1 and R2).

S=0

I=0

L1: if x>y goto L2

Z=s+a[i]

I=i+1

Goto L1

L2:

7. (6 分 ) Give out the all basic blocks of the following program fragment and construct the relevant flow graph(DAG).

read C

A=0

B=1

L4: A=A+B

if B>C goto L2

B=B+1

goto L4

L2: write A

8.(8 分 )Translate the assignment statement b[i]=b*c-b*d into

(1) A syntax tree.

(2)Three address instructions.

答案::

(1)栈式动态存储分配

(2)堆式动态存储分配

(3)左

(4)语法分析

(5)目标代码生成

(6)表格管理

(7)xyz*ab+/+

(8)继承属性

(9)a+(i-1)*20+j-1

(10)基本块

-----

一、选择题(每问 2 分,共20 分)

1.C B

2.D

3.B

4.A

5.D

6.A,C

7.BCD,选对一个得 1 分且不超过满分,选错一个扣一分,扣完为止。

8.BCD,选对一个得

1 分且不超过满分,选错一个扣一分,扣完为止。

二、解答题

1.( 1)文法存在左递归,消除左递归后的文法为:

E→ (E)E ’ |i E’(2分)

E’→ TEE’ | ε(2分)

T→ *|+(1 分)

(2)(5 分) 没考虑 #扣 0.5分,其它错或少写一个扣0.5 分

FIRST(E)={(,i} FIRST(E’ )={*,+,ε } FIRST(T)={*,+}

FOLLOW(E)={),*,+,#} FOWLLOW(E’ )= {),*,+,#} FOLLOW(T)={(,i}

( 3)每错一个扣0.5 分,全错或不写不得分,扣完为止,共 5 分

()i*+#

E E→ (E)E ’E→ iE ’

E’E’→εE’→ TEE’E’→ TEE’E’ → ε

E’ →εE’ →ε

T T→ *T→ +

2.( 1)规范推导过程如下。写错推导符号扣0.5 分, 错写或少写一步推导扣0.5 分,扣完为止,最左推导扣2分,共 4分。

S S(S)S()S( S)()S( )()S(S)()()S(S( S))()()S(S( ))()()S(S(S)())()() S(S()())()()S(()())()()(()())()()

( 2)( 1)中加下划线的部分是句柄,标识如(1)。每少写一个句柄扣0.5 分,扣完为止,共 4 分。( 3)每少写步扣0.5 分,扣完为止,共 4 分。

S

S( S )

)

S( S )ε

)

S( S )ε

)

εS( S )

)

S ( S )ε

)

3.( 1)打印的字符串是:12020(错一个扣0.5 分,共 3 分)

( 2)归约过程中错一步扣0.5 分,扣完为止。(共 5 分)

4.( 1)每少写一步扣0.5 分,扣完为止,共 5 分。

S

while M1.q=100E1.t=102do M2.q=102S1

E1.f=107

εa

E2.f=103

(E3.t=102)εL.p=x:=

E4.p=T1

c>d x E5.p=y+

E6.p=z

y z ( 2)少写一个四元式扣0.5 分,全错或不写不得分,回填错误扣0.5 分,共 5 分。

四元式序列为:

100( j ,a, b,102)

101( j , _, _,107)

102( j,c, d ,104)

103(( j, _, _,106)

104( , y, z, T1)

105(: , T1, _, x)

106( j , _, _,100)

5.( 1)少写一个扣 1 分,全错或不写不得分,共 5 分。

FIRSTVT(S)={a,∧ ,(}

FIRSTVT(T)={, a,∧,(}

LASTVT(S)={ a,∧ ,)}

LASTVT(T)={ a,∧ ,),, }

(2) 优先表如下。每错一个扣0.5 分,全错或不写不得分,扣完为止,共 3 分

文法G[S] 没有两个非终结符相邻的情况,且其优先表中任一对终结符之间最多满足?、?、三种关系中的一种,因此是G[S] 算符优先文法。( 2 分)

可以不考虑终结符“#”。

a∧(),#

A???

∧???

(????

)??

,??????

#????

或者

( 3)优先函数。可以不考虑终结符“#”。每错一个扣0.5分,全错或不写不得分,扣完为止,共 5 分。

a∧(),#

f662662

g777252

或者

a∧(),

f44244

g55523

三、填空题(每空 2 分,共 20 分)

1目标程序(target code)语法分析( syntax analyzer)代码优化器( code optimizer )代码产生器( code generator )符号表管理( symbol table manager)

2继承属性( inherited attribute)

3局部优化( local optimization)

4四元式( quatriple )

5 E+ * ( ) id

四、单项选择题(每题 2 分,共 10 分)

1.B

2.D

3.B

4.D

5.C

五、解答题(共 70 分)

1.( 1) L(G)={0 m1m|M ≥1}共2分,≥写成>扣 1 分

( 2) S=>0S1=>00S11=>000111,共 3 分, => 写成 -> 扣 1 分

( 3)共 3 分,错处扣 0.5分,扣完为止

2. ( 1)空白表格也可以填写“错误”字样, 共 4 分,错一个扣 0.5分,扣完为止

a b c$(#)

S S→ aBc S→ bAB

A A→ aAb A→ b

B B→ b B→ εB→ ε

( 2)共 6 分,其中判断“baabbb 是该文法句子”为 2 分,其他错一个扣0.5 分,扣完为止符号栈输入串规则

$S baabbb$

$BAb baabbb$S→ bAB

$BA aabbb$

$BbAa aabbb$A→ aAb

$BbA abbb$

$BbbAa abbb$A→ aAb

$BbbA bbb$

$Bbbb bbb$A→ b

$Bbb bb$

$Bb b$

$b$B→ ε

$$success

3.(1)共 6 分,其中判断“该文法为算符优先文法”为 2 分,其他错一个扣0.5 分,扣完为止

+*i

+><<

*>><

i>>

(2)共 4 分,错一个扣 0.5 分,扣完为止

+*i

f244

g135

4.( 1) 34242421,共4 分,错一个扣0.5 分

(2)共 4 分,错一个扣0.5 分,扣完为止

stack Input string action

$b(((aa)a)a)b$

$b(((aa)a)a)b$shift

$b(((aa)a)a)b$abbb$shift

$b(((aa)a)a)b$bbb$shift

$b(((aa)a)a)b$bb$shift

$b(((a a)a)a)b$$shift

$b(((A a)a)a)b$reduce, A→ a

$b(((Aa)a)a)b$shift

$ b(((Aa)a)a)b$shift

$ b(((B a)a)b$reduce, B→ Aa)

$b((A a)a)b$reduce, A→ (B

$b((Aa)a)b$shift

$b((Aa)a)b$shift

$b(( B a)b$reduce, B→ Aa)

$b(A a)b$reduce, A→ (B

$b(Aa)b$shift

$b(Aa)b$shift

$b(B b$reduce, B→ Aa)

$bA b$reduce, A→ (B

$bAb$shift

$S$reduce, S→ bAb

$s$accept

5.共 12 分,其中带注释的分析树、三地址码序列和四元式序列分别为 4 分,错一个序列扣0.5 分,而错某点(某项)少于或等于5个扣 0.5 分

带注释语法树 ( 略 )

三地址码序列四元式序列

M1: if (x>y) goto M2100 (j>, x,y,102)

goto M4101 (j,-,-,108)

M2: if (a=b) goto M3102 (j=,a,b,104)

goto M1103 (j,-,-,100)

M3: t1=2*y104 (*,2,y,t1)

t2=t1+a105 (+,t1,a,t2)

x=t2106 (=,t2,-,x)

goto M1107 (j,-,-,100)

M4:108 (-,-,-,-)

6.共 8 分,错一个扣 0.5分,扣完为止

LD R1,0

ST S,R1

ST I,R1

L1: LD R1,X

SUB R1,R1,Y (OR SUB R1,Y)

BGTZ R1,L2

LD R2,a(R1)

ADD R2,R2,S (OR ADD R2,S)

ST Z,R2

LD R1,I (从这开始,下面的语句中的R1 也可以全部变成R2) ADD R1,R1,1 (OR INC R1)

ST I,R1

BR L1

L2:

7.共 6 分,基本块划分和流图各为 3 分,错一处扣 1 分,扣完为止

B1 B2 B3read c

A=0

B=1

L4: A=A+B

If B>C goto L2 (OR B4)

B=B+1

Goto L4 (OR B2)

B4L2: 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.( )称为规范推导。

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. 语法 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)

是二义性的。 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

的分析过程。

l

b m

c l a n b n |

8. 写一个文法 G, 使其语言为 L(G)={a l>=0, m>=1, n>=2}

9. 已知文法 G(S): S → a| (T) T → T,S|S 的优先关系表如下:

关系 a ( ) , a - - .> .> ( <. <. =. <.

) - - .> .>

,

<.

<.

.>

.>

请计算出该优先关系表所对应的优先函数表。

10. 何谓优化?按所涉及的程序范围可分为哪几级优化?

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

12. 一字母表 Σ ={a, b} ,试写出 Σ 上所有以 a 为首的字组成的正规集相对应的正规式。

13. 基本的优化方法有哪几种?

14. 写一个文法 G, 使其语言为 L(G)={ab n c n | 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} ,则正规式 a* b|b * a 表示的正规集是什么?

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 的值是什么21. 写一个文法G, 使其语言为L(G)={a n b n c m| n>0为奇数,

m>0 为偶数}

22. 写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列。

23.一个文法 G别是 LL(1) 文法的充要条件是什么?

24.已知文法 G[S]

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

if c>0 then a:=a+1

else a:=a*3-1;

翻译成四元式序列。

6.设有基本块

D:=A-C

E:=A*C

F:=D*E

S:=2

T:=A-C

Q:=A*C

G:=2*S

J:=T*Q

K:=G*5

L:=K+J

M:=L

假设基本块出口时只有M还被引用,请写出优化后的四元序列。

7.已知文法 G(S)

S→ a | ^ | (T)

T→T,S|S

(1)给出句子 (a,(a,a)) 的最左推导;

(2)给出句型 ((T,S),a) 的短语 , 直接短语,句柄。

8. 对于 C 语言 do S while E语句

(1)改写文法,使之适合语法制导翻译;

(2)写出改写后产生式的语义动作。

9.已知文法 G(S)

S→ aAcBe

A → Ab| b

B→ d

(1)给出句子 abbcde 的最左推导及画出语法树;

(2)给出句型 aAbcde 的短语、素短语。

10.设文法 G(S):

S→ (T) | aS | a

T→T,S | S

⑴消除左递归和提公共左因子;

⑵构造相应的FIRST 和 FOLLOW集合;

⑶构造预测分析表。

11.把语句

if X>0∨ Y<0

then while X>0 do X:=A*3

else Y:=B+3;

翻译成四元式序列。

12.已知文法 G(S)

E→E+T | T

T →T*F| F

F → (E)| i

(1)给出句型 (i+i)*i+i的最左推导及画出语法树;

(2)给出句型 (E+T)*i+F 的短语,素短语和最左素短语。

13.设文法 G( S):

S→T|S ∨T

T→U |T ∧U

U→ i |-U

(1)计算 FIRSTVT 和 LASTVT;

(2)构造优先关系表。

-----

参考答案

一、是非题:

1.×

2.×

3.×

4.√

5.√

6.×

7.×

8.×

9.√ 10.× 11.×

12. √ 13.× 14.√ 15.√ 16.√ 17.× 18.√ 19.√ 20.× 21.√ 22.√

二、填空题:

1.( 最右推导)

2.( 词法分析),(语法分析),(中间代码生成),(代码优化),(目标代码生成)

3.( 二义性的)

4.( 执行性),(说明性)

5.( 单词符号),(语法单位)。

6.( 源程序),(单词符号)

7.( 类型、种属、所占单元大小、地址)

8.( 现行活动记录地址和所有外层最新活动记录的地址)

9.( 句柄)

10.( 栈式 ) ,(堆式)

11.( 类型 ) ,(作用域)

12.( 传地址),(传值),(传名)

13.( 局部优化),(循环优化),(全局优化)

14.( 自上而下),(自下而上)

15.( 分析表),(符号栈)

16.( 传地址),(传值),(传名)

17.( 初),(终)

18.( 局部优化),(循环优化),(全局优化)

19.( 语法),(语义)

20.( 句柄)

21.(LL(1)文法)

22.( 静态),(动态)

23.( 二义性文法)

24.( 规范推导),(规范)

25.( 自上而下),(自下而上)

26.( 句子 )

27.( 从开始符号出发,向下推导,推出句子)

28.( 单词符号),(语法单位)

29.( 局部优化)

30.( 分析表),(符号栈)

31.( 上下文无关文法),(正规)

32.( 指令访问主存次数加1)

33.( 最左素短语)

三、名词解释题:

1.局部优化 ------- 局限于基本块范围的优化称。

2.二义性文法 ------ 如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义性文法。

3.DISPLAY 表 ----过程的嵌套层次显示表,记录该过程的各外层过程的最新活动记录的起始地址。

4.词法分析器 ----- 执行词法分析的程序。

5.最左推导 ------ 任何一步α=>β都是对α中的最右非终结符替换。

6.语法 ------ 一组规则,用它可形成和产生一组合式的程序。

7.文法 ------ 描述语言的语法结构的形式规则。

8.基本块 ------ 指程序中一顺序执行的语句序列,其中只有一个入口和一个出口,入口就是其中的第一个语句,出

口就是其中的最后一个语句。

9.语法制导翻译------ 在语法分析过程中,根据每个产生式所对应的语义子程序进行翻译的办法叫做语法制导翻译。

10. 短语 ------令G是一个文法,S划文法的开始符号,假定α β δ 是文法G的一个句型,如果有Sα Aδ且

Aβ,则称β是句型α β δ相对非终结符A 的短语。

第1页共25页

编译原理期末试题(含答案+大题集+重要知识点)

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

A.( ) xyx B.( ) (xyx)* C.( ) xnyxn(n≥0) D.( ) x*yx* 4.如果文法G是无二义的,则它的任何句子α_____。 A.( )最左推导和最右推导对应的语法树必定相同 B.( ) 最左推导和最右推导对应的语法树可能不同 C.( ) 最左推导和最右推导必定相同 D.( )可能存在两个不同的最左推导,但它们对应的语法树相同 5.构造编译程序应掌握______。 A.( )源程序B.( ) 目标语言 C.( ) 编译方法D.( ) 以上三项都是 6.四元式之间的联系是通过_____实现的。 A.( ) 指示器B.( ) 临时变量 C.( ) 符号表D.( ) 程序变量 7.表达式(┐A∨B)∧(C∨D)的逆波兰表示为_____。 A. ( ) ┐AB∨∧CD∨B.( ) A┐B∨CD∨∧ C.( ) AB∨┐CD∨∧D.( ) A┐B∨∧CD∨ 8. 优化可生成_____的目标代码。 A.( ) 运行时间较短 B.( ) 占用存储空间较小 C.( ) 运行时间短但占用内存空间大D.( ) 运行时间短且占用存储空间小9.下列______优化方法不是针对循环优化进行的。 A. ( ) 强度削弱B.( ) 删除归纳变量 C.( ) 删除多余运算D.( ) 代码外提 10.编译程序使用_____区别标识符的作用域。

编译原理期末考试卷与答案

态存储分配方案和动态存储分配方案,而后者又分为(1) 和 (2) 。 2. 规范规约是最(3)规约。 3. 编译程序的工作过程一般划分为5个阶段:词法分析、(4) 、语义分析与中间代码生成,代码优化及(5) 。另外还有(6)和出错处理。 4.表达式x+y*z/(a+b)的后缀式为 (7) 。 5.文法符号的属性有综合属性和 (8)。 6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..20]某个元素a[i ,j]的地址 计算公式为(9)。 7.局部优化是局限于一个(10)范围内的一种优化。 二. 选择题(1-6为单选题,7-8为多选题,每问2分,共20分) 1. 一个上下文无关文法G 包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组 ( )。 A . 字符串 B . 产生式 C . 开始符号 D . 文法 2.程序的基本块是指( )。 A . 一个子程序 B . 一个仅有一个入口和一个出口的语句 C . 一个没有嵌套的程序段 D . 一组顺序执行的程序段,仅有一个入口和一个出口 3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于( )分析方法。 A . 自左向右 B . 自顶向下 C . 自底向上 D . 自右向左 4.在通常的语法分析方法中,( )特别适用于表达式的分析。 A . 算符优先分析法 B . LR 分析法 C . 递归下降分析法 D . LL (1)分析法 5.经过编译所得到的目标程序是( )。 A . 四元式序列 B . 间接三元式序列 C . 二元式序列 D . 机器语言程序或汇编语言程序 6. 一个文法所描述的语言是( );描述一个语言的文法是( )。 A . 唯一的 B . 不唯一的 C . 可能唯一,也可能不唯一 7. 如果在文法G 中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。 A . 其最左推导和最右推导相同 B . 该句子有两个不同的最左推导

编译原理期末试题(8套含答案+大题集)

《编译原理》期末试题(五) 一、单项选择题(共10小题,每小题2分,共20分) 1.语言是 A.句子的集合B.产生式的集合 C.符号串的集合D.句型的集合 2.编译程序前三个阶段完成的工作是 A.词法分析、语法分析和代码优化 B.代码生成、代码优化和词法分析 C.词法分析、语法分析、语义分析和中间代码生成 D.词法分析、语法分析和代码优化 3.一个句型中称为句柄的是该句型的最左 A.非终结符号B.短语C.句子D.直接短语 4.下推自动机识别的语言是 A.0型语言B.1型语言 C.2型语言D.3型语言 5.扫描器所完成的任务是从字符串形式的源程序中识别出一个个具有独立含义的最小语法单位即 A.字符B.单词C.句子D.句型 6.对应Chomsky四种文法的四种语言之间的关系是 A.L0?L1?L2?L3 B.L3?L2?L1?L0 C.L3=L2?L1?L0D.L0?L1?L2=L3 7.词法分析的任务是 A.识别单词B.分析句子的含义 C.识别句子D.生成目标代码 8.常用的中间代码形式不含 A.三元式B.四元式C.逆波兰式D.语法树 9.代码优化的目的是 A.节省时间B.节省空间 C.节省时间和空间D.把编译程序进行等价交换 10.代码生成阶段的主要任务是 A.把高级语言翻译成汇编语言 B.把高级语言翻译成机器语言 C.把中间代码变换成依赖具体机器的目标代码 D.把汇编语言翻译成机器语言 二、填空题(本大题共5小题,每小题2分,共10分) 1.编译程序首先要识别出源程序中每个(单词),然后再分析每个(句子)并翻译其意义。2.编译器常用的语法分析方法有(自底向上)和(自顶向下)两种。 3.通常把编译过程分为分析前端与综合后端两大阶段。词法、语法和语义分析是对源程序的(分析),中间代码生成、代码优化与目标代码的生成则是对源程序的(综合)。 4.程序设计语言的发展带来了日渐多变的运行时存储管理方案,主要分为两大类,即(静态存储分配)方案和(动态存储分配)方案。 5.对编译程序而言,输入数据是(源程序),输出结果是(目标程序)。

编译原理期末试题及答案

1、试为表达式 w+(a+b)*(c+d/(e-10)+8) 写出相应的逆波兰表示。 2、写出表达式a+b*(c-d)/e的逆波兰式和三元序列。 3、写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列。 4、已知文法G(S)及相应翻译方案 S→aAb {print “1”} S→a {print “2”} A→AS {print “3”} A→c {print “4”} 输入acab, 输出是什么? 5、已知文法G(S) S→bAa A→(B | a B→A a) 写出句子b(aa)b的规范归约过程。 6、已知文法G[S] S→S*aF | aF | *aF F→+aF | +a 消除文法左递归。 1、设文法G(S): S→^ | a | (T) T→T,S | S ⑴ 消除左递归; ⑵ 构造相应的FIRST和FOLLOW集合; ⑶ 构造预测分析表 2.语句 if E then S (1) 改写文法,使之适合语法制导翻译; (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)写出每个产生式对应的语义动作。 7.已知文法G(S) S→a | ^ | (T) T→T,S | S (1) 给出句子(a,(a,a))的最左推导; (2) 给出句型((T,S),a)的短语, 直接短语,句柄。 8.对于 C 语言do S while E语句

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

一. 填空题(每空2分,共20分) 1. 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静态存储分配方案和动态存储分配方案,而后者又分为(1) 和 (2) 。 2. 规范规约是最(3)规约。 3. 编译程序的工作过程一般划分为5个阶段:词法分析、(4) 、语义分析及中间代码生成,代码优化及(5) 。另外还有(6)和出错处理。 4.表达式*()的后缀式为 (7) 。 5.文法符号的属性有综合属性和 (8)。 6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..20]某个元素a[i ,j]的地址计算公式为(9)。 7.局部优化是局限于一个(10)范围内的一种优化。 二. 选择题(1-6为单选题,7-8为多选题,每问2分,共20分) 1. 一个上下文无关文法G 包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组( )。 A . 字符串 B . 产生式 C . 开始符号 D . 文法 2.程序的基本块是指( )。 A . 一个子程序 B . 一个仅有一个入口和一个出口的语句 C . 一个没有嵌套的程序段 D . 一组顺序执行的程序段,仅有一个入口

和一个出口 3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于()分析方法。 A.自左向右 B.自顶向下 C.自底向上 D.自右向左 4.在通常的语法分析方法中,()特别适用于表达式的分析。 A.算符优先分析法 B.分析法 C.递归下降分析法 D.(1)分析法 5.经过编译所得到的目标程序是()。 A.四元式序列 B.间接三元式序列 C.二元式序列 D.机器语言程序或汇编语言程序6.一个文法所描述的语言是();描述一个语言的文法是()。 A.唯一的 B.不唯一的 C.可能唯一,也可能不唯一7.如果在文法G中存在一个句子,当其满足下列条件()之一时,则称该文法是二义文法。 A.其最左推导和最右推导相同 B.该句子有两个不同的最左推导C.该句子有两个不同的最右推导 D.该句子有两棵不同的语法树E.该句子对应的语法树唯一

电子科技大学22春“计算机科学与技术”《计算机编译原理》期末考试高频考点版(带答案)试卷号:4

电子科技大学22春“计算机科学与技术”《计算机编译原理》期末考试高 频考点版(带答案) 一.综合考核(共50题) 1. 文法G产生的()的全体是该文法描述的语言。 A.句型 B.终结符集 C.非终结符集 D.句子 参考答案:D 2. 若文法G定义的语言是无限集,则文法必然是()。 A.递归的 B.前后文无关的 C.二义性的 D.无二义性的 参考答案:A 3. 一个句型中的最左()称为该句型的句柄。 A.短语 B.简单短语 C.素短语 D.终结符号 参考答案:B 4. 编译程序:如果源语言为某台计算机上的汇编语言或机器语言,目标语言为高级语言,则此翻译程序称为编译程序。() A.正确 B.错误

5. LR(1)分析法的名字中,“L”的含义是()。 A.自右向左进行分析 B.采用最右推导的逆过程——最左归约 C.向貌似句柄的符号串后查看1个输入符号 D.自左向右进行分析 参考答案:D 6. 继承属性值的计算依赖于分析树中它的()的属性值。 A.父结点 B.子结点 C.兄弟结点 D.父结点与子结点 E.父结点与兄弟结点 参考答案:ACE 7. 词法分析器的输出是()。 A.单词符号 B.源程序 C.语法单位 D.目标程序 参考答案:A 8. 已知文法G[S]:S→AB|PQx,A→xy,B→bc,P→dP|ε,Q→aQ|ε,该文法是LL(1)文法。() A.正确 B.错误 参考答案:B

A.单词 B.句子 C.表达式 D.词法 参考答案:A 10. 由文法G[S]的开始符S经n步(n≥0)推导产生的文法符号序列α是()。 A.待选式 B.句子 C.句型 D.正规式 参考答案:C 11. 代码优化依据的原则是()。 A.语法规则 B.等价变换原则 C.词法规则 D.程序结构的描述规则 参考答案:B 12. 编译方法中自顶向下的语法分析算法有()。 ①简单优先分析方法②算符优先分析方法③递归子程序法④LL(K)分析方法⑤SLR方法⑥LR(K)方法 ⑦LALR(K)方法⑧预测分析方法。 A.①②③⑧ B.④⑤⑥⑦ C.①②⑤⑥⑦ D.③④⑧ E.③④⑦⑧ F.③④ 参考答案:D

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

期末考试试卷(A)卷 一、填空题(每小题2分,共20分) 1、字母表∑,用∑*表示∑上所有有穷长的串集合,∑*称为∑的①。 2、设z=abc,则z的固有头是①。 3、如何由语言基本符号组成程序中各个语法成分(包括程序)的一组规则叫 ①。 4、设∑={a,b},∑上的正规式(a|b)(a|b) 相应的正规集为① 5、NFA的映象f是从"状态×字"映射到"状态子集",f为①值函数。 6、LR分析是按规范句型的①为可归约串。 7、结点的①属性值由该结点的兄弟结点和父结点的属性值计算。 8、如果分析树中一结点的属性b依赖于属性c,那么这个结点的属性b的语义规 则的计算必须在定义属性c的语义规则的计算①。 9、对于栈式符号表,引入一个显示嵌套层次关系表- ①表,该表总是 指向当前正在处理的最内层的过程的子符号表在栈符号表中的起始位置。 10、任一有向边序列n1 → n2,n2 → n3,…,nk-1 → nk为从结点n1到结点nk 的一条通路。如果n1=nk,则称该通路为①。 二、单项选择(每小题2分,共14分) 1、乔姆斯基把文法分成4种类型,即0型、1型、2型和3型。其中3型文法也称 为()。 A.上下无关文法 B.正规文法 C.上下文有关文法 D.无限制文法 2、生成非0开头的正偶数集的文法是()。 A. Z::=ABC B. Z::=ABC C::=0|2|4|6|8 C::=0|2|4|6|8 B::=BA|B0|ε B::=BA|B0|0 A::=1|2|3|…|9 A::=1|2|3|…|9 C. Z::=ABC|2|4|6|8 D. Z::=ABC|2|4|6|8 C::=0|2|4|6|8 C::=0|2|4|6|8 B::=BA|B0|0 B::=BA|B0|ε

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

态存储分配方案和动态存储分配方案,而后者又分为〔1 〕 和 〔2〕 。 2. 标准规约是最〔3〕规约。 3. 编译程序的工作过程一般划分为5个阶段:词法分析、〔4〕 、语义分析与中间代码生成,代码优化及〔5〕 。另外还有〔6〕和出错处理。 4.表达式x+y*z/(a+b)的后缀式为 〔7〕 。 5.文法符号的属性有综合属性和 〔8〕。 6.假设二位数组按行存放,而且每个元素占用一个存储单元,那么数组a[1..15,1..20]某个元素a[i ,j]的地 址计算公式为〔9〕。 7.局部优化是局限于一个〔10〕范围内的一种优化。 二. 选择题〔1-6为单项选择题,7-8为多项选择题,每问2分,共20分〕 1. 一个上下文无关文法G 包括四个组成局部:一组终结符,一组非终结符,一个〔 〕,以及一组 〔 〕。 A . 字符串 B . 产生式 C . 开始符号 D . 文法 2.程序的根本块是指〔 〕。 A . 一个子程序 B . 一个仅有一个入口和一个出口的语句 C . 一个没有嵌套的程序段 D . 一组顺序执行的程序段,仅有一个入口和一个出口 3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于〔 〕分析方法。 A . 自左向右 B . 自顶向下 C . 自底向上 D . 自右向左 4.在通常的语法分析方法中,〔 〕特别适用于表达式的分析。 A . 算符优先分析法 B . LR 分析法 C . 递归下降分析法 D . LL 〔1〕分析法 5.经过编译所得到的目标程序是〔 〕。 A . 四元式序列 B . 间接三元式序列 C . 二元式序列 D . 机器语言程序或汇编语言程序 6. 一个文法所描述的语言是〔 〕;描述一个语言的文法是〔 〕。 A . 唯一的 B . 不唯一的 C . 可能唯一,也可能不唯一 7. 如果在文法G 中存在一个句子,当其满足以下条件〔 〕之一时,那么称该文法是二义文法。 A . 其最左推导和最右推导相同 B . 该句子有两个不同的最左推导

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

一. 填空题(每空2分,共20分) 1. 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静 态存储分配方案和动态存储分配方案,而后者又分为(1) 和 (2) 。 2. 规范规约是最(3)规约。 3. 编译程序的工作过程一般划分为5个阶段:词法分析、(4) 、语义分析与中间代码生成,代码优化及(5) 。另外还有(6)和出错处理。 4.表达式x+y*z/(a+b)的后缀式为 (7) 。 5.文法符号的属性有综合属性和 (8)。 6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..20]某个元素a[i ,j]的地址 计算公式为(9)。 7.局部优化是局限于一个(10)范围内的一种优化。 二. 选择题(1-6为单选题,7-8为多选题,每问2分,共20分) 1. 一个上下文无关文法G 包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组( )。 A . 字符串 B . 产生式 C . 开始符号 D . 文法 2.程序的基本块是指( )。 A . 一个子程序 B . 一个仅有一个入口和一个出口的语句 C . 一个没有嵌套的程序段 D . 一组顺序执行的程序段,仅有一个入口和一个出口 3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于( )分析方法。 A . 自左向右 B . 自顶向下 C . 自底向上 D . 自右向左 4.在通常的语法分析方法中,( )特别适用于表达式的分析。 A . 算符优先分析法 B . LR 分析法 C . 递归下降分析法 D . LL (1)分析法 5.经过编译所得到的目标程序是( )。 A . 四元式序列 B . 间接三元式序列 C . 二元式序列 D . 机器语言程序或汇编语言程序 6. 一个文法所描述的语言是( );描述一个语言的文法是( )。 A . 唯一的 B . 不唯一的 C . 可能唯一,也可能不唯一 7. 如果在文法G 中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。 A . 其最左推导和最右推导相同 B . 该句子有两个不同的最左推导 C . 该句子有两个不同的最右推导 D . 该句子有两棵不同的语法树

编译原理期末试题及答案

1、试为表达式 w+(a+b)*(c+d/(e-10)+8) 写出相应的逆波兰表示。 2、写出表达式a+b*(c-d)/e的逆波兰式和三元序列。 3、写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列。 4、已知文法G(S)及相应翻译方案 S→aAb {print “1”} S→a {print “2”} A→AS {print “3”} A→c {print “4"} 输入acab, 输出是什么? 5、已知文法G(S) S→bAa A→(B | a B→A a) 写出句子b(aa)b的规范归约过程. 6、已知文法G[S] S→S*aF | aF |*aF F→+aF | +a 消除文法左递归。 1、设文法G(S): S→^ | a | (T) T→T,S | S ⑴ 消除左递归; ⑵ 构造相应的FIRST和FOLLOW集合; ⑶ 构造预测分析表 2.语句 if E then S (1)改写文法,使之适合语法制导翻译; (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)写出每个产生式对应的语义动作。 7。已知文法G(S) S→a | ^ | (T) T→T,S | S (1) 给出句子(a,(a,a))的最左推导; (2) 给出句型((T,S),a)的短语, 直接短语,句柄。 8。对于 C 语言do S while E语句 (1)改写文法,使之适合语法制导翻译; (2)写出改写后产生式的语义动作.

《编译原理》期末考试题库含答案.docx

《编译原理》模拟试题一 一、是非题(请在括号内,正确的划错误的划X)(每个2分,共20分) 1•计算机高级语言翻译成低级语言只有解释一种方式。(X) 2.在编译中进行语法检查的目的是为了发现程序中所有错误。(X) 3.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。(丁 ) 4.正则文法其产生式为A->a , A->Bb, A.BGVN , a、beVT o (X) 5.每个文法都能改写为LL(1)文法。(V) 6.递归下降法允许任一非终极符是直接左递归的。(V) 7.算符优先关系表不一定存在对应的优先函数。(X) 8.自底而上语法分析方法的主要问题是候选式的选择。(X) 9.LR法是自顶向下语法分析方法。(X) 10.简单优先文法允许任意两个产生式具有相同右部。(X) 二、选择题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)(每个4分,共40分) 1.一个编译程序中,不仅包含词法分析,_____ ,中间代码生成,代码优化,目标代码生成等五个部分。 A.()语法分析 B.()文法分析 C.()语言分析 D.()解释分析 2.词法分析器用于识别_____ o A.()字符串 B.()语句 C.()单词 D.()标识符 3 •语法分析器则可以发现源程序中的______ o A.()语义错误 B.()语法和语义错误 C.()错误并校正 D.()语法错误

4.下面关于解释程序的描述正确的是。

(1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于COBOL 和FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A. ( ) (1) (2) B. () (1) C. () (1)⑵(3) D.()⑵⑶ 5. _________________________________________ 解释程序处理语言时,大多数采用的是 ___________________________________ 方法。 A.()源程序命令被逐个直接解释执行 B. ()先将源程序转化为中间代码,再解释执行 C. ()先将源程序解释转化为目标程序,再执行 D. ()以上方法都可以 6. _______________________________________ 编译过程中,语法分析器的任务就是 ___________________________________ (1)分析单词是怎样构成的 (2) 说明的 (3)分析语句和说明是如何构成程序的 B. ( ) (2) (3) (4) D. ( ) (1) (2) (3) (4) 7. ____________________ 编译程序是一种 8. ___________________________ 文法G 所描述的语言是 的集合。 A. ()文法G 的字母表V 中所有符号组成的符号串 B. ()文法G 的字母表V 的闭包V*中的所有符号串 C. ()由文法的开始符号推出的所有终极符串 D. ()由文法的开始符号推出的所有符号串 9. 文法分为四种类型,即0型、1型、2型、3型。其中3型文法是 ____ - A.()短语文法 B.()正则文法 C. ()上下文有关文法 D.()上下文无关文法 10. 一个上下文无关文法G 包括四个组成部分,它们是:一组非终结符号,一 组终结符号,一个开始符号,以及一组 _____ o A.()句子 B.()句型 C.()单词 D.()产生式 分析单词串是如何构成语句和 (4)分析程序的结构 A. ( ) (2) (3) C. ( ) (1) (2) (3) A.()汇编程序 C.()解释程序 B.()翻译程序 D.()目标程序

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

3. 髙级语言编译程序常用的语法分析方法中,递归下降分析法属于()分析方法。 4. 在通常的语法分析方法中,()特別适用于表达式的分析。 5. 经过编译所得到的目标程序是( 一・填空题 (每空2分,共20分) 1.不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静 态存储分配方案和动态存储分配方案,而后者又分为(1)和(2) O 2.规范规约是最(3)规约。 3.编译程序的工作过程一般划分为5个阶段:词法分析v (4 ).语义分析和中间代码生成,代码优化及V ) o 另外还有(6)和出错处理。 4.表达式x+y*z∕(a+b )的后缀式为—(7)。 5.文法符号的属性有综合属性和(8). 6•假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15, 1..20]某个元素a[i, j]的地址 计算公式为(9)o 7.局部优化是局限于一个空L 范圉内的一种优化。 A.字符串 选择题 (1-6为单选题,7-8为多选题,每问2分,共20分) 1. 一个上下文无关文法G 包括四个组成部分:一组终结符,一组非终结符,一个(),以及一组 )o B.产生式 C.开始符号 D. 文法 2•程序的基本块是指()。 A. 一个子程序 B. 一个仅有一个入口和一个岀口的语句 C. 一个没有嵌套的程序段 D. 一组顺序执行的程序段,仅有一个入口和一个出口 A. 自左向右 B. 自顶向下 C. 自底向上 D. 自右向左 A.算符优先分析法 B. LR 分析法 C.递归下降分析法 D. LL (1)分析法 A. 四元式序列 B. 间接三元式序列 C. 二元式序列 D. 机器语言程序或汇编语言程序 6. 一个文法所描述的语言是(); 描述一个语言的文法是()o A. 唯一的 B.不唯一的 C.可能唯一,也可能不唯一 7. 如果在文法G 中存在一个句子, 当其满足下列条件()之一时,则称该文法是二义文法。 A. 其最左推导和最右推导相同 B.该句子有两个不同的最左推导

编译原理期末考试题目及答案

一、填空题(每空2分,共20分) 1.编译程序首先要识别出源程序中每个单词,然后再分析每个句子并翻译其意义. 2.编译器常用的语法分析方法有自底向上和自顶向下两种。 3.通常把编译过程分为分析前端与综合后端两大阶段。词法、语法和语义分析是对源程序的分析,中间代码生成、代码优化与目标代码的生成则是对源程序的综合. 4.程序设计语言的发展带来了日渐多变的运行时存储管理方案,主要分为两大类,即静态存储分配方案和动态存储分配方案。 5.对编译程序而言,输入数据是源程序,输出结果是目标程序. 1.计算机执行用高级语言编写的程序主要有两种途径:解释和编译. 2.扫描器是词法分析器,它接受输入的源程序,对源程序进行词法分析并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。 3.自下而上分析法采用移进、归约、错误处理、接受等四种操作。 4.一个LL(1)分析程序需要用到一张分析表和符号栈。 5.后缀式abc-/所代表的表达式是a/(b—c)。 二、单项选择题(每小题2分,共20分) 1.词法分析器的输出结果是__C。 A.单词的种别编码B.单词在符号表中的位置 C.单词的种别编码和自身值D.单词自身值 2.正规式M 1 和M 2 等价是指__C_。 A.M1和M2的状态数相等 B.M1和M2的有向边条数相等 C.M1和M2所识别的语言集相等D.M1和M2状态数和有向边条数相等 3.文法G:S→xSx|y所识别的语言是_C____. A.xyx B.(xyx)* C.xnyxn(n≥0)D.x*yx* 4.如果文法G是无二义的,则它的任何句子α_A____. A.最左推导和最右推导对应的语法树必定相同B.最左推导和最右推导对应的语法树可能不同 C.最左推导和最右推导必定相同D.可能存在两个不同的最左推导,但它们对应的语法树相同5.构造编译程序应掌握____D__。 A.源程序B.目标语言C.编译方法D.以上三项都是 6.四元式之间的联系是通过__B___实现的。 A.指示器B.临时变量C.符号表D.程序变量 7.表达式(┐A∨B)∧(C∨D)的逆波兰表示为__B___. A.┐AB∨∧CD∨B.A┐B∨CD∨∧ C.AB∨┐CD∨∧D.A┐B∨∧CD∨ 8。优化可生成__D___的目标代码。 A.运行时间较短 B.占用存储空间较小 C.运行时间短但占用内存空间大D.运行时间短且占用存储空间小 9.下列___C___优化方法不是针对循环优化进行的. A. 强度削弱B.删除归纳变量C.删除多余运算D.代码外提 10.编译程序使用_B_区别标识符的作用域。 A. 说明标识符的过程或函数名B.说明标识符的过程或函数的静态层次 C.说明标识符的过程或函数的动态层次 D. 标识符的行号 三、判断题(对的打√,错的打×,每小题1分,共10分) 2.一个有限状态自动机中,有且仅有一个唯一的终态。x 3.一个算符优先文法的每个非终结符号间都也可能存在优先关系。X 4.语法分析时必须先消除文法中的左递归。X 6.逆波兰表示法表示表达式时无须使用括号。R 9.两个正规集相等的必要条件是他们对应的正规式等价。X

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

一. 填空题(每空2分,共20分) 1。 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种: 静态存储分配方案和动态存储分配方案,而后者又分为(1) 和 (2) 。 2. 规范规约是最(3)规约。 3。 编译程序的工作过程一般划分为5个阶段:词法分析、(4) 、语义分析与中间代码生成,代码优化及(5) .另外还有(6)和出错处理。 4.表达式x+y*z/(a+b )的后缀式为 (7) 。 5.文法符号的属性有综合属性和 (8)。 6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a [1。.15,1。。20]某个元素a [i ,j]的地址计算公式为(9)。 7.局部优化是局限于一个(10)范围内的一种优化。 二. 选择题(1-6为单选题,7—8为多选题,每问2分,共20分) 1。 一个上下文无关文法G 包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组( )。 A . 字符串 B . 产生式 C . 开始符号 D . 文法 2。程序的基本块是指( )。 A . 一个子程序 B . 一个仅有一个入口和一个出口的语句 C . 一个没有嵌套的程序段 D . 一组顺序执行的程序段,仅有一个入口和一个出口 3。 高级语言编译程序常用的语法分析方法中,递归下降分析法属于( )分析方法. A . 自左向右 B . 自顶向下 C . 自底向上 D . 自右向左 4.在通常的语法分析方法中,( )特别适用于表达式的分析。 A . 算符优先分析法 B . LR 分析法 C . 递归下降分析法 D . LL(1)分析法 5.经过编译所得到的目标程序是( )。 A . 四元式序列 B . 间接三元式序列 C . 二元式序列 D . 机器语言程序或汇编语言程序 6. 一个文法所描述的语言是( );描述一个语言的文法是( )。 A . 唯一的 B . 不唯一的 C . 可能唯一,也可能不唯一 7. 如果在文法G 中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。 A . 其最左推导和最右推导相同 B . 该句子有两个不同的最左推导 C . 该句子有两个不同的最右推导 D . 该句子有两棵不同的语法树

编译原理_南京邮电大学中国大学mooc课后章节答案期末考试题库2023年

编译原理_南京邮电大学中国大学mooc课后章节答案期末考试题库2023年 1.左线性文法画状态转换图时,文法的开始符号对应的终止状态 答案: 正确 2.e1= (a|b)*,e2=(a*b*)* e1和e2等价 答案: 正确 3.一张状态转换图只包含有限个状态,其中有一个被认为是初态,最多只有一个 终态。 答案: 错误 4.简单优先分析法是一种规范归约分析法 答案: 正确 5.S∷=aAa | aBb| bAb| bBa A∷=x B∷=x 该文法不是LALR(1)文法 答案: 正确 6.LL(1)文法无左递归、无二义性。

答案: 正确 7.文法:E∷=EE+ | EE* | aFOLLOW(E)={+,*,#} 答案: 错误 8.LR分析栈中存放的状态是识别文法规范句型()的DFA的状态。 答案: 活前缀 9.已知文法A∷=BCc | gDBB∷=ε| bCDEC∷=DaB | caD∷=ε| dD E∷=gAf | cFOLLOW(B)={} 答案: { a,c,d,g,f,#} 10.表达式(a+b)/(a-b)-(b*c)的四元式序列为:⑴.(+,a,b,T1)⑵.(- ,a,b,T2)⑶.(/,T1,T2,T3)⑷.(*,b,c,T4)⑸.(-,T3,T4,T5) 答案: 正确 11.编译程序与具体的机器有关。 答案: 正确

12.由文法的开始符经0步或多步推导产生文法符号序列是句子。 答案: 错误 13.如果在进行归约时,文法的某些规范句型的句柄不唯一,则称该文法是二义 性文法。 答案: 正确 14.规范归约又称为最右归约。 答案: 错误 15.假设有一文法,如果文法G中没有形如A::=....BC....这样的规则,其中A、B 和C都为非终结符号,则称该文法为() 答案: 算符文法 16.递归下降分析法属于()分析方法 答案: 自顶向下 17.由正规文法构造状态转换图,其右线性文法识别符号对应是状态转换图的初 始状态。

相关主题
文本预览
相关文档 最新文档