文档库 最新最全的文档下载
当前位置:文档库 › 编译原理复习题

编译原理复习题

编译原理复习题
编译原理复习题

一、单项选择题 概述部分

1.构造编译程序应掌握 。D A. 源程序 B. 目标语言 C. 编译方法 D. 以上三项都是 2.编译程序绝大多数时间花在 上。D

A. 出错处理

B. 词法分析

C. 目标代码生成

D. 表格管理 3.编译程序是对 。D

A. 汇编程序的翻译

B. 高级语言程序的解释执行

C. 机器语言的执行

D. 高级语言的翻译 4. 将编译程序分成若干“遍”,是为了 。B

A. 提高程序的执行效率

B. 使程序的结构更为清晰 C 利用有限的机器内存并提高机器的执行效率 D. 利用有限的机器内存但降低了机器的执行效率

词法分析部分

1.DFA M(见图1-1)接受的字集为 。D A. 以0开头的二进制数组成的集合

B. 以0结尾的二进制数组成的集合

C. 含奇数个0的二进制数组成的集合

D. 含偶数个0的二进制数组成的集合

2.词法分析器的输出结果是 。C

A. 单词的种别编码

B. 单词在符号表中的位置

C. 单词的种别编码和自身值

D. 单词自身值 3.正规式M1和M2等价是指 。C A. M1和M2的状态数相等 B. M1和M2的有向边条数相等 C. M1和M2所识别的语言集相等 D. M1和M2状态数和有向边条数相等 4.词法分析器的加工对象是 。 C A .中间代码 B .单词 C .源程序 D .元程序 5.同正规式(a|b )*等价的正规式为 。D A .(a|b)+ B .a*|b* C .(ab)* D .(a*|b*)+ 6. 两个DFA 等价是指: 。 D A. 这两个DFA 的状态数相同

B. 这两个DFA 的状态数和有向弧条数都相等

C. 这两个DFA 的有向弧条数相等

D. 这两个DFA 接受的语言相同

7. 下列符号串不可以由符号集S ={a,b}上的正闭包运算产生的是:(A ) A. ε B. a C. aa D. ab 8.称有限自动机A1和A2等价是指________。D A .A1和A2都是定义在一个字母表上的有限自动机 B .A1和A2状态数和有向边数相等

图1-1

1

C.A1和A2状态数或有向边数相等

D.A1和A2所能识别的字符串集合相等

9.同正规式(a|b)+等价的正规式是_______。B

A.(a|b)* B.(a|b)(a|b)*

C.(ab)*(ab)D.(a|b)|(a|b)*

语法分析

1.在规范归约中,用来刻画可归约串。 B

A. 直接短语

B. 句柄

C. 最左素短语

D. 素短语

2.若B为非终结符,则A→α·Bβ为项目。D

A. 归约

B. 移进

C. 接受

D. 待约

3.如果文法G是无二义的,则它的任何句子α。 A

A. 最左推导和最右推导对应的语法树必定相同

B. 最左推导和最右推导对应的语法树可能不同

C. 最左推导和最右推导必定相同

D. 可能存在两个不同的最左推导,但它们对应的语法树相同

4.下列动作中,不是自下而上分析动作的是:。B

A. 移进

B. 展开

C. 接受

D. 报错

6.若a为终结符,则A→α·aβ为项目。B

A. 归约

B. 移进

C. 接受

D. 待约

7.语法分析时所依据的是。A

A. 语法规则

B. 词法规则

C. 语义规则

D. 等价变换规则

8.文法G:S→xSx|y所识别的语言是。C

A. xyx

B. (xyx)*

C. x n yx n (n≥0)

D. x*yx*

9.下列动作中,不是自上而下分析动作的是:。C

A. 匹配

B. 展开

C. 移进

D. 报错

10.若A为非终结符,则A→α·为项目。A

A. 归约

B. 移进

C. 接受

D. 待约

11.文法G:S→xSx| xS|y所识别的语言是。 A

A. x m yx n(m≥n≥0)

B. (xyx)*

C. x n yx n(n≥0)

D. x*yx*

13.由文法的开始符号出发经过若干步(包括0步)推导产生的文法符号序列称为______。B A.语言B.句型C.句子D.句柄

14.在自上而下的语法分析中,应从开始分析。C

A.句型B.句子C.文法开始符号D.句柄

15.一个文法G,若________,则称它是LL(1)文法。C

A.G中不含左递归B.G无二义性

C.G的LL(1)分析表中不含多重定义的条目D.G中产生式不含左公因子

16.项目S’→S. 为。D

A.归约项目

B.移进项目

C.待约项目

D.接受项目

17. 语法分析器的输入是:。A

A. Token序列

B. 源程序

C. 目标程序

D. 符号表

18. 在LR(0)的Action表中,如果某行中存在标记为“rj”的栏,则:。A

A. 该行必定填满“rj”

B. 该行未必填满“rj”

C. 其他行可能也有“rj”

D. goto表中也可能有“rj”

19. LR分析过程中栈内存储的是。A

A. 活前缀

B. 前缀

C. 归约活前缀

D. 项目

20.文法G:S → x xS | y 所识别的语言是。D

A.xxy n B.(xxy) n

C.xx n yx D.(xx)n y

21.若状态k含有项目“A→α.”,对任意非终结符a,都用规则“A →α”归约的语法分析方法是。B A.LALR分析法B.LR(0)分析法

C.LR(1)分析法D.SLR(1)分析法

22. 在SLR(1)的Action表中,如果某行中存在标记为“rj”的栏,则:。B

A. 该行必定填满“rj”

B. 该行未必填满“rj”

C. 其他行可能也有“rj”

D. goto表中也可能有“rj”

23. 一个指明了在LR分析过程中的某个时刻所能看到产生式多大一部分。D

A. 活前缀

B. 前缀

C. 归约活前缀

D. 项目

24.若状态k含有项目“A→α.”,且仅当输入符号a∈FOLLOW(A)时,才用规则“A →α”归约的语法分析方法是。D

A.LALR分析法B.LR(0)分析法

C.LR(1)分析法D.SLR(1)分析法

25.设有文法G[T]:

T→T*F|F

F→F↑P|P

P→(T)|a

该文法句型T*P↑(T*F)的句柄是下列符号串。C

A.(T*F)

B. T*F

C. P

D. P↑(T*F)

26.LR分析表中的转移表(goto)是以作为列标题的。B

A.终结符B.非终结符C.终结符或非终结符D.表示状态的整形数

27.编译程序的语法分析器必须输出的信息是。A

A.语法错误信息B.语法规则信息

C.语法分析过程D.语句序列

28.下列项目中为可移进项目的是。C

A.E′→E . B.L→. C.L→.-L D.F→L*F.

29.LR分析表中的动作表(action)是以作为列标题的。D

A.终结符B.非终结符

C.终结符或非终结符D.终结符和结束符#

30.下列项目中为可归约项目的是。B

A.E′→.E B.L→. C.L→-.L D.F→L*.F

33.LR分析器的核心部分是一张分析表,该表由_________组成。D

A.ACTION表B.GOTO表

C.预测分析表D.ACTION表和GOTO表

34.在递归下降子程序方法中,若文法存在左递归,则会使分析过程产生__ _____。D

A.回溯B.非法调用C.有限次调用D.无限循环

35.最左简单子树的叶结点,自左至右排列组成句型的________。C

A.短语B.句型C.句柄D.间接短语

36.由文法的开始符号出发经过若干步(包括0步)推导产生的文法符号序列中,如果只含有终结符,则文法符号序列称为________。C

A.语言B.句型C.句子D.句柄

37.LL(1)分析法中“1”的含义是在输入串中查看一个输入符号,其目的是________。C

A.确定最左推导B.确定句柄

C.确定使用哪一个产生式进行展开D.确定是否推导

语义分析

1.表达式(┐a∨b)∧(e∨f)的逆波兰表示为。B

A.┐ab∨∧ef∨B.a┐b∨ef∨∧

C.ab∨┐ef∨∧D.a┐b∨∧ef∨

2.中间代码生成时所依据的是。C

A.词法规则B.语法规则

C.语义规则D.等价变换规则

3.-a-(b*c/(c-d)+(-b)*a)的逆波兰表示是。(@代表后缀式中的求负运算符) C

A. abc*cd-b@a*+/-@

B. a@bc*cd-b@a*+/-

C. a@bc*cd-/b@a*+-

D. a@bc*/cd-b@a*+-

4.有文法G及其语法制导翻译如下所示(语义规则中的*和+分别是常规意义下的算术运算符):E→E(1)∧ T {E.val = E(1).val * T.val}

E→T {E.val = T.val}

T→T(1)# n {T.val = T(1).val + n.val }

T→ n {T.val = n.val}

则分析句子1 ∧ 2 ∧ 3 # 4其值为。 C

A. 10

B. 34

C. 14

D.54

5.有文法G及其语法制导翻译如下所示(语义规则中的*和+分别是常规意义下的算术运算符):E→E(1)∧ T {E.val = E(1).val * T.val}

E→T {E.val = T.val}

T→T(1)# n {T.val = T(1).val + n.val }

T→ n {T.val = n.val}

则分析句子2 ∧ 3 # 4其值为。 C

A. 10

B. 21

C. 14

D. 24

6.间接三元式表示法的优点为。A

A. 采用间接码表,便于优化处理

B. 节省存储空间,不便于表的修改

C. 便于优化处理,节省存储空间

D. 节省存储空间,不便于优化处理

7.文法G[S]及其语法制导翻译定义如下:

产生式语义动作

S’ → S print(S.num)

S → (L) S.num = L.num +1

S → a S.num = 0

L →L(1), S L.num = L(1).num + S.num

L →S L.num = S.num

若输入为(a,(a)),且采用自底向上的分析方法,则输出为。C

A.0 B.1 C.2 D.4

8.四元式之间的联系是通过____________实现的。B

A.指示器B.临时变量C.符号表D.程序变量

9.表达式(┐a∨b)∧(c∨d)的逆波兰表示为。B

A.┐ab∨∧cd∨B.a┐b∨cd∨∧

C.ab∨┐cd∨∧D.a┐b∨∧cd∨

10.表达式a+b+c+d的逆波兰表示为。B

A.a+bc+d+ B.ab+c+d+

C.ab+cd++ D.abc+d++

11.有文法G及其语法制导翻译如下所示(语义规则中的*和+分别是常规意义下的算术运算符):

E→E(1) ∧T {E.val = E(1).val * T.val}

E→T {E.val = T.val}

T→T(1)# n {T.val = T(1).val + n.val }

T→n {T.val = n.val}

则分析句子3 ∧3 # 4其值为。B

A. 10

B. 21

C. 14

D. 24

12.表达式a+b+c的逆波兰表示为。B

A.a+bc+ B.ab+c+

C.+abc+ D.abc++

13. 文法G[S]及其语法制导翻译定义如下:

产生式语义动作

S’ → S print(S.num)

S → (L) S.num = L.num +1

S → a S.num = 0

L →L(1), S L.num = L(1).num + S.num

L →S L.num = S.num

若输入为(a, a),且采用自底向上的分析方法,则输出为。B

A.0 B.1

C.2 D.4

14.有一语法制导翻译定义如下:

S→bAb print “1”

A→(B print “2”

A→a print “3”

B→aA) print “4”

若输入序列为b(a(a(aa)))b,且采用自底向上的分析方法,则输出序列为。B A.32224441 B.34242421

C.12424243 D.34442212

15.赋值语句X:=-(a+b)/(c-d)-(a+b*c)的逆波兰表示是。C

A.Xab+cd-/-bc*a+-:=

B.Xab+/cd-bc*a+--:=

C.Xab+-cd-/ a bc* +-:=

D.Xab+cd-/abc* +--:=

16.有一语法制导翻译定义如下,其中+表示符号连接运算:

S→B print B.vers

B→a B.vers=a

B→b B.vers=b

B→Ba B.vers=a+B.vers

B→Bb B.vers=b+B.vers

若输入序列为abab,且采用自底向上的分析方法,则输出序列为。D

A.aabb B.abab C.bbaa D.baba

17.编译程序不能检查、处理的错误是程序中的________。B

A.静态语义检查B.动态语义检查C.语法错误D.词法错误

(优化、存储、错误管理)

1.在编译过程中,如果遇到错误应该。C

A. 把错误理解成局部的错误

B. 对错误在局部范围内进行纠正,继续向下分析

C. 当发现错误时,跳过错误所在的语法单位继续分析下去

D. 当发现错误时立即停止编译,待用户改正错误后再继续编译

二、填空题

概述部分:

1.编译程序的开发常常采用自编译、交叉编译、自展和移植等技术实现。

2.解释程序和编译程序的区别在于是否生成目标程序。

3.如果编译程序生成的目标程序是汇编语言程序,则源程序的执行分为3个阶段:编译阶段、汇编阶段和运行阶段。

4.编译程序工作过程中,第一阶段输入是源程序,最后阶段的输出为目标程序。

5.编译过程通常可分为5个阶段词法分析阶段、语法分析阶段、语义分析和中间代码生成阶段、优化阶段和目标代码生成阶段。

6.如果编译阶段生成的目标程序是某特定计算机系统的机器代码程序,则源程序的执行分为两大阶段:编译阶段和运行阶段。

7.对编译程序而言,输入数据是源程序,输出结果是目标程序。

8.贯穿于编译程始终的工作有符号表处理和出错处理。

词法分析部分:

1.词法分析的工作是将源程序中的字符串变换成单词符号流的过程,所遵循的是语言的构词规则。

2.若两个正规式所表示的正规集相同,则认为二者是等价的。

3.若两个正规式所表示的正规集相同,则认为二者是等价的。

4.正规式R1和R2等价是指_______表示相同的正规集。

5.词法分析器的输入是源程序字符串,输出结构是二元式(单词种别,单词自身的值)。词法分析所遵循的是语言的构词规则。

6.确定的有限自动机是一个五元组,包含的五个元分别是:状态集合、字母表、初态、终态集、状态转换函数集合。

7.有限自动机是更一般化的状态转换图,它分为确定的有限自动机DFA 和非确定的有限自动机NFA

两种。

8.NFA和DFA的区别主要有两点:其一是NFA可以有若干个初始状态,而DFA仅有一个初始状态;其二是NFA的状态转换函数f不是单值函数,而是一个多值函数。

语法分析部分:(基本概念、LL(1)、LR(0)、SLR(1)、递归下降子程序)

1.语法分析的方法通常分为两类:自上而下分析方法和自下而上分析方法。

2.文法中的终结符集和非终结符集的交集是空集。

3.一个句型的最左直接短语称为该句型的___句柄________________。

4.规范归约是最右推导的逆过程。

5.自下而上语法分析中分析器的动作有_移进、____归约、__接受_ 、__报错__。

6.自上而下语法分析中分析器的动作有___匹配终结符____、__展开非终结符_、__分析成功、报错__。7.常用的自上而下语法分析方法有递归下降子程序方法和预测分析表方法(LL(1)方法)。

8.常用的自下而上语法分析方法有算符优先分析法和LR分析法。

9.一个LL(1)分析器由一张LL(1)分析表(预测分析表)、一个先进后出分析栈和一个控制程序(表驱动程序)组成。

10.一个LR分析器由分析栈、分析表和总控程序三个部分组成。

11.LR(0)分析法的名字中,“L”表示自左至右分析输入串,“R”表示采用最右推导的逆过程即最左归约。“0”表示向右查看0个字符。

12.LL(1)分析法中,第一个L的含义是从左到右扫描输入串;第二个L的含义是分析过程中采用最左推导;“1”的含义是只需向右查看一个符号就可以决定如何推导。

13.LR(1)文法的含义是:L表明_____自左至右扫描输入串__,R表明___采用最右推导的逆过程(最左归约)方法进行分析__。

14.一个上下文无关文法是LL(1)文法的充分必要条件是:对每一个非终结符A的任何两个不同产生式A →α|β,有下面的条件成立:(1)FIRST(α)∩FIRST(β) = ? ;(2)假若ε

β?,则有FIRST(α)

∩ FOLLOW(A) = ?。

15.对于LL(1)文法中的任何产生式A→α|β,则需要满足__First(_α)∩First(β)= Φ、

_若_β=>*ε,则_ First(_α) ∩__Follow(A)=_ Φ_。

16.LR分析器的核心部分是一张分析表,该表包括动作(ACTION)表和状态转换(GOTO)表等两个子表。

17.关于非终结符A的直接左递归产生式:A→Aα|β,其中α、β是任意的符号串且β不以A开头,则可以将A的产生式改写为右递归的形式为:A→βA’, A’→αA’|ε。

18.在消除回溯,提取公共左因子时,关于A的产生式A →δβ1 | δβ2 | … | δβi | βi+1 | …| βj,可以改写为: A →δA’ | βi+1 | …| βj,A’→β1 | … |βi。

19.设G[S] 是一文法,如果符号串x是从识别符号推导出来的,即有

*

?

S x,则称x是文法G[S]的____

句型__,若x仅由终结符号组成,即

*

*

,

T

V

x

x

S∈

?,则称x为文法G[S]的__句子。

20.已知文法G[S]:

S→eT|RT T→DR|εR→dR|εD→a|bd

求FIRST(S)={e,d,a,b,ε}______;FOLLOW(D)=_{d,#} 。

语义处理部分:

1.文法符号的属性有两种,一种称为继承属性,另一种称为综合属性。

2.编译过程中,常见的中间语言形式有逆波兰表示法、抽象语法树、三元式、四元式。3.语法制导翻译的方法就是为每个产生式配上一个翻译子程序(语义动作或语义子程序),并在语

法分析的同时执行它们。

4.编译过程中,常见的中间语言形式有逆波兰表示法、抽象语法树、三元式、四元式。6.文法符号的属性有两种,一种称为继承属性,另一种称为综合属性。

7.四元式之间的联系是通过临时变量实现的。

8.在属性文法中,终结符只有____综合属性。

10.语法制导翻译的方法就是为每个产生式配上一个翻译子程序(语义动作或语义子程序),并在语法分析的同时执行它们。

11.目前较常见的语言语义的描述形式是__属性文法______,并使用__语法制导翻译方法完成对语法成分的翻译。

(优化、存储、错误管理)

1.代码优化的含义是:对代码进行等价变换,使得变换后的代码具有更高的时间效率和空间效率。

2.按照优化对象所涉及的程序范围,优化分为局部优化、循环优化和全局优化。

3.基本块,是指程序中—顺序执行的语句系列,其中只有一个入口和一个出口。

4.从编译角度看,分配目标程序数据空间的基本策略有:静态分配策略、动态分派策略和堆式动态分配策略。

三、判断题

1.设r和s分别为正规式,则有L(r|s) = L(r) | L(s).。( ×)

2.一个文法的所有句型的集合形成该文法所能接受的语言。( ×)

3.语法分析之所以采用上下文无关文法是因为它的描述能力最强。( ×)

4.由于LR(0)分析表构造简单,所以它的描述能力强,适用面宽;LR(1)分析表因构造复杂而描述能力弱,适用面窄。( ×)

5.逆波兰表示法表示表达式时无需使用括号。( √)

6.自动机M和M’的状态个数不同,则二者必不等价。( ×)

7.LL(1)文法一定不含左递归和二义性。( √)

8.所有LR分析器的总控程序都是一样的,只是分析表各有不同。( √)

9.无论是三元式表示还是间接三元式表示的中间代码,其三元式在三元式表中的位置一旦确定就很难改变。( √)

10.三地址语句类似于汇编语言代码,可以看成中间代码的一种抽象形式。( √)

11.最左推导也被称为规范推导。(×)

12.运算对象排列的先后顺序在后缀式和中缀式中不同。(×)

13.出现在移进-归约分析器栈中的内容被称为文法G的活前缀。(√)

14.LR方法可以分析含有左递归的文法。(√)

15.三元式的编号具有双重含义,既代表此三元式,又代表三元式存放的结果。(√)

16.语义规则中的属性有两种:综合属性与继承属性。(√)

17.移进-归约分析器的格局中栈的内容一般是文法符号与状态。(√)

18.由于递归下降子程序方法较LL(1)方法简单,因此它要求文法不必是LL(1)文法。(×)19.四元式的编号具有双重含义,既代表此四元式,又代表四元式存放的结果。(×)

20.用高级语言编写的源程序必须经过编译,产生目标程序后才能运行。(×)

21.源程序到目标程序的变换是等价变换,即两者结构不同,但语义是一致的。(√)

22.对于任何一个正规式e,都存在一个DFA A,使得L(e)=L(A)。(√)

23.最小化的DFA,它的状态数最小。(√)

24.NFA的确定化算法具有消除ε边的功能。(√)

25.每个非终结符产生的终结符号串都是该语言的子集。(×)

26.一个语言的文法是不唯一的。(√)

27.语法错误校正的目的是为了把错误改正过来。(×)

28.源程序和目标程序是等价关系。(√)

29.编译程序中错误处理的任务是对检查出的错误进行修改。(×)

30.使用有限自动机可以实现单词的识别。(√)

31.一个非确定的有限自动机NFA可以通过多条路径识别同一个符号串。(√)

32.最小化的DFA所识别接受的正规集最小。(×)

33.一个语言(如C语言)的句子是有穷的。(×)

34.LL(1)方法又称为预测分析方法。(√)

35.一个LL(1)文法是无二义和无回溯方法。(√)

36.语法分析器可以检查出程序中的所有错误。(×)

37.LR分析法是自上而下的语法分析方法。(×)

三、多项选择题

1. 编译器的各个阶段的工作都涉及到(AE)

A. 表格处理

B. 词法分析

C. 语法分析

D. 语义分析

E. 出错处理

2. 令∑={a,b},则∑上的符号串的全体可用下面的正规式表示。(ABE)

A. (a|b)*

B. (a*|b*)*

C. (a|b)+

D. (ab)*

E. (a*b*)*

3. 自上而下的分析方法有:(AD)

A. 递归下降分析法

B. LR(0)分析法

C. LALR(1)分析法

D. LL(1)分析法

E. SLR(1)分析法

4.文法G:G[S]:S→CD Ab→bA

C→aCA Ba→aB

C→bCB Bb→bB

AD→aD C→ε

BD→bD D→ε

Aa→bD

是(A)。

A. 0型文法

B. 1型文法

C. 2型文法

D. 3型文法

E. 上下文有关文法

5. 对LR分析表的构造,有可能存在的动作冲突有:(AD)

A. 移进/归约冲突

B. 移进/移进冲突

C. 归约冲突

D. 归约/归约冲突

E. 移进冲突

6. 一个编译器可能有的阶段为(ABCDE)

A. 词法分析

B. 语法分析

C. 语义分析

D. 中间代码生成

E. 目标代码生成

7 令∑={a,b},则∑上的所有以b开头,后跟若干个(可为0个)ab的符号串的全体可用下面的正规式表示。(AB)

A.b (ab)*

B. (ba)*b

C. b(a|b)+

D. (ba)+b

E. b (a|b)*

8. 自下而上的分析方法有:(BCE)

A. 递归下降分析法

B. LR(0)分析法

C. LALR(1)分析法

D. LL(1)分析法

E. SLR(1)分析法

9. 一般来说,编译器可分为前端和后端,下列编译阶段可被划分为编译的前端的有:(ABCDE)

A. 词法分析

B. 语法分析

C. 语义分析

D. 中间代码生成

E. 中间代码优化

10.令∑={a,b},则∑上的符号串的全体可用下面的正规式表示。(ABE)

A. (a|b)*

B. (a*|b*)*

C. (a|b)+

D. (ab)*

E. (a*b*)*

11.下列符号串是符号集∑={a,b}上的正规式的有:(ABCDE)

A. ε

B. a

C.ab

D.(ab|a) (ab|a)

E.ab|ab

12.正规式服从的代数规律有:(ABDE)

A. “或”运算服从交换律

B. “或”运算服从结合律

C. “连接”运算服从交换律

D. “连接”运算服从结合律

E. “连接”运算可对“或”运算进行分配

13.令∑={a,b},则∑上的所有以b开头,后跟若干个(可为0个)ab的符号串的全体可用下面的正规式表示。(AB)

A.b (ab)*

B. (ba)*b

C. b(a|b)+

D. (ba)+b

E. b (a|b)*

14.一个LR分析器包括:(ADE)

A. 一个总控程序

B.一个项目集

C.一个活前缀

D.一个分析栈

E.一张分析表

15.LR分析器的核心部分是一张分析表,该表包括(DE)等子表。

A. LL(1)分析表

B. LR(1)分析表

C. SLR(1)分析表

D. Action表

E. goto表

16.Action表中的每一项Action[S,a]所表示的动作可能为:(ABCD)

A. 移进

B. 接受

C. 归约

D. 出错

E. 待约

五.简答题

1.构造正规表达式((a|b)*|aa)*b的NFA。

解:

2.设M=({x,y}, {a,b}, f, x, {y})为一非确定的有限自动机,其中f 定义如下: f(x,a)={x,y} f {x,b}={y} f(y,a)=Φ f{y,b}={x,y} 试构造相应的确定有限自动机M ′。

解:对照自动机的定义M=(S,Σ,f,So,Z),由f 的定义可知f(x,a)、f(y,b)均为多值函数,因此M 是一非确定有限自动机。 先画出NFA M 相应的状态图,如下图所示。

b

用子集法构造状态转换矩阵,如下表所示。

将转换矩阵中的所有子集重新命名,形成下表所示的状态转换矩阵,即得到

M ′=({0,1,2},{a,b},f,0,{1,2})M ′状态转换图如下图所示。

(注意:本题由于集合的命名和先后顺序不同,可能最终结果不同。)

3.画出编译程序的总体结构图,简述各部分的主要功能。

解:编译程序的总体框图如下所示:

a, b

(1)词法分析器,又称扫描器,它接受输入的源程序,对源程序进行词法分析,识别出一个个单词符号,其输出结果是二元式(单词种别,单词自身的值)流。

(2)语法分析器,对单词符号串进行语法分析(根据语法规则进行推导或归约),识别出程序中的各类语法单位,最终判断输入串是否构成语法上正确的句子。

(3

)语义分析及中间代码生成器,按照语义规则对语法分析器归约出(或推导出)的语法单位进行语义分析并把它们翻译成一定形式的中间代码。编译程序可以根据不同的需要选择不同的中间代码形式,有的编译程序甚至没有中间代码形式,而直接生成目标代码。

(4)优化器对中间代码进行优化处理。一般最初生成的中间代码执行效率都比较低,因此要做中间代码的优化,其过程实际上是对中间代码进行等价替换,使程序在执行时能更快,并占用更小的空间。 (5)目标代码生成器,把中间代码翻译成目标程序。中间代码一般是一种与机器无关的表示形式,只有把它再翻译成与机器硬件直接相关的机器能识别的语言,即目标程序,才能在机器上运行。

(6)表格管理模块保持一系列的表格,登记源程序的各类信息和编译各阶段的进展状况。编译程序各个阶段所产生的中间结果都记录在表格中,所需要的信息也大多从表格中获取,整个编译过程都在不断和表格打交道。

(7)出错处理程序对出现在源程序中的错误进行处理。如果源程序有错误,编译程序应设法发现错误,把有关错误信息报告给用户。编译程序的各个阶段都有可能发现错误,出错处理程序要对发现的错误进行处理、记录,并反映给用户。

4.构造一个DFA ,它接受Σ = {0, 1}上所有满足如下条件的字符串:每个1后面都有0直接跟在右边。 解:(1)0*(0|10)*0* 或者 (0|10)*

2)

①NFA (2分)

②子集法确定化

重新命名状态,即得:

③最小化

首先分为终态集和非终态集{3} {1, 2, 4} 因为10 = 2 20 = 2 40 = 4 状态均属于集合{1, 2, 4},所以对于输入符号0不能区分开1,2,4三个状态;11 = 3 21 = 3 41 = 3状态均属于集合{3},所以对于输入符号1也不能区分开1,2,4三个状态;因此最终的状态划分即为: {3} {1, 2, 4},其对应的DFA如下图所示:

5.写出C语言标识符集(字母或下划线开头的由字母、数字、下划线构成的串)的正规式。

解答:用D表示数字0-9,用L表示字母a-z|A-Z,则C语言标识符的正规式为:

(L|_)(L|D|_)*

语法分析部分:

6.构造一文法,使其描述的语言L = {ω |ω∈ (a, b)*,且ω中含有相同个数的a和b}。

解:

S→ε| aA|bB

A→ b| bS| aAA

B→ a| aS| bBB

7.对于文法G(S):

S → (L) | aS | a

L → L, S | S

(1) 画出句型(S, (a))的语法树。

(2) 写出上述句型的所有短语、直接短语和句柄。

解:

(1) 句型(S, (a))的语法树如下图所示:

(2) 从语法树中可以找到(3分)短语:a; (a); S; S,(a); (S, (a))

直接短语:a; S

句柄:S

8.令文法G[N]为G[N]: N→D|ND

D→0|1|2|3|4|5|6|7|8|9

给出句子568的最左、最右推导。

解:最左推导:N ?ND ?NDD ?DDD ?5DD ?56D ?568 最右推导:N ?ND ?N8 ?ND8?N68 ?D68 ?568 8.已知文法G[A]: A→aABl|a

B→Bb|d

试给出与G[A]等价的LL(1)文法G[A′];

解:G[A′]:A→aA′

A′→ABl | ε

B→dB′

B′→bB′| ε

9.试构造下述文法的SLR(1)分析表。

G[A]: A→aABl|a

B→Bb|d

解:拓广文法

(0)S→A

(1)A→aABl

(2)A→a

(3)B→Bb

(4)B→d

First(A)={a}follow(A)={#,d}

First(B)={d}follow(B)={l}

G[S]: S→(L)|a

L→L,S|S

解:消除左递归:

G(S): S → (L) | a

L → SL’

L’→, SL’| ε

构造FIRST集,如下:

(1)FIRST(S) = {(, a}

(2)FIRST(L) = {(, a}

(3)FIRST(L’) = {,, ε}

构造FOLLOW集如下:

(1)FOLLOW(S) = {#, ,, )}

(2)FOLLOW(L) = {)}

(3)FOLLOW(L’) = {)}

11.已知文法G[S]: S→aSbS|bSaS|ε

试证明G[S]是二义文法

证明:该文法产生的语言是a的个数和b的个数相等的串的集合。该文法二义,例如句子abab有两种不同的最左推导。

S?aSbS?abS?abaSbS?ababS?abab

S?aSbS?abSaSbS?abaSbS?ababS?abab

12.已知文法G:

S →( L | a

L →S , L | )

判断是不是LL(1)文法,如果是请构造文法G的预测分析表,如果不是请说明理由。

【解】

1)求各非终结符的FISRT 集和FOLLOW 集:

= { (, a )

FIRST(L) = { a }? FIRST(S) = { (, ), a }

FOLLOW(S) = {, # }

FOLLOW(L) = FOLLOW(S) ={ , # }

FIRST(( L)∩{a}=Φ

FIRST(S , L)∩{)}=Φ

所以是LL(1)文法

2

13.文法

S → A a | b A c | d c | b d a

A → d

构造识别活前缀的DFA 。请根据这个DFA 来判断该文法是不是SLR(1)文法并说明理由。

Follow(S)={#}

Follow(A)={a,c}

I4存在冲突且Follow(A)∩{c}={ c} I7存在冲突且Follow(A)∩{a}={ a} 所以不是SLR(1)文法

14.设有文法G[S]:

S →S*S|S+S|(S)|i

该文法是否为二义文法,并说明理由?

【解】该文法是二义文法,因为该文法存在句子i*i+i,该句子有两棵不同的语法树如图所示。

S

S *

S S S (1)

+

S

S + S S S (2)

*

i

i

i

15.构造下面文法的LL (1)分析表。 G[D]: D → TL

T → int | real L → id R

R → , id R | ε

【解】FIRST(T)={ int real } FOLLOW(T)={ id } FIRST(L)={ id } FOLLOW(L)={ #} FIRST(R)={ , ε} FOLLOW(R)={ #}

FIRST(D)={ int real } FOLLOW(D)={#} 因为FIRST(int)∩FIRST(real)=Φ

FIRST(, id R )∩FOLLOW(R)=Φ

所以是LL

16.给定文法S→aS|bS|a,下面是拓广文法和识别该文法所产生的活前缀的DFA。判断该文法是否是SLR(1)文法:如果是构造其SLR(1)分析表,如果不是请说明理由。

(1)将文法G(S)拓广为G(S’):

(0)S’→S

(1)S→aS

(2)S→bS

(3)S→a

(2)识别该文法所产生的活前缀的DFA如图1所示。

图1

【解】注意到状态I1存在“移进-归纳”冲突,计算S的FOLLOW集合:

FOLLOW(S)={#}

{a}∩{b}∩FOLLOW(R)=Φ

可以采用SLR冲突消解法,得到如下的SLR分析表。

从分析表可以看出,表中没有冲突项,所以该文法是SLR(1)文法。

表1 SLR分析表

17.证明下面文法S→AaAb|BbBa A→εB→ε,是LL(1)文法,但不是SLR(1)文法。

证明:

(1)first(AaAb)={a} first(BbBb)={b} ,有first(AaAb)∩first(BbBb)=Φ

所以根据LL(1)文法的定义,该文法是LL(1)文法。

(2)为了构造识别活前缀的DFA,初态集包含如下四个项目:S→.AaAb S→.BbBa A→.B→. 但该项目中有两个可归约项目:A→.B→.,产生归约-归约冲突,而follow(A)={a,b},follow(B)={a,b},有follow(A)∩follow(B)≠Φ,所以使用向前看一个终结符的方法不能解决此冲突,所以该文法不是SLR(1)文法。

18.已知文法G(S):

S→S*aP| aP| *aP

P→+aP| +a

(1) 将文法G(S)改写为LL(1)文法G’(S);

(2) 写出文法G’(S)的预测分析表。

解:

(1)消除左递归,文法变为:

S→aPS’| *aPS’

S’→ *aPS’ | ε

P→+aP| +a

提取公共左因子,文法变为G’(S):

S→aPS’| *aPS’

S’→ *aPS’ |ε

P→+aP’

P’→P| ε

(2)计算每个非终结符的FIRST集和FOLLOW集:

FIRST(S) = {a, *} FOLLOW(S) = {#}

FIRST(S’) = {*, ε} FOLLOW(S’) = {#}

FIRST(P) = {+} FOLLOW(P) = {*, #}

FIRST(P’) = {+, ε} FOLLOW(P’) = {*, #}

构造该文法的预测分析表如下:

19.已知文法G(S):

S→aS | bS | a

(1) 构造识别该文法所产生的活前缀的DFA;

(2) 判断该文法是LR(0)还是SLR(1),并构造所属文法的LR分析表。解:

(1)将文法G(S)拓广为G’(S’):

(0) S’→S

(1) S→aS

(2) S→bS

(3) S→a

识别该文法所产生的活前缀的DFA:

(2)在状态I2存在“移近-归约”冲突,因此该文法不是LR(0)文法。

计算S的FOLLOW集合:

FOLLOW(S)= {#}

I2中的冲突用FOLLOW集合可以解决,所以该文法是SLR(1)文法。

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

一、填空题|(每题4分,共20分) 1. 乔母斯基定义的3型文法(线性文法)产生式形式 A→Ba|a,或A→aB|a,A,B∈Vn, a,b∈Vt 。 2.语法分析程序的输入是单词符号,其输出是语法单位。 3 型为 B → .aB 的LR(0)项目被称为移进项目,型为 B → a.B 的LR(0) 项目被称为待约项目, 4.在属性文法中文法符号的两种属性分别为继承属性和综合属性。 5、运行时存贮管理方案有静态存储分配、动态存储分配和堆式存储分配和方案。 二.已知文法 G(S) (1) E → T | E+T (2) T → F | F*F (3) F →(E)| i (1)写出句型(T*F+i)的最右推到并画出语法树。(4分) (2)写出上述句型的短语,直接短语和句柄。(4分) 答:(1)最右推到(2分) E ==> T ==> F ==> (E) ==> (E+T) ==> (E+F) ==> (E+i) ==> (T+i) ==> (T*F+i) (2) 语法树(2分) (3)(4分) 短语:(T*F+i),T*F+i ,T*F , i 直接短语:T*F , i 句柄:T*F 三. 证明文法G(S) :S → SaS |ε是二义的。(6分) 答:句子aaa对应的两颗语法树为:

因此,文法是二义文法 四.给定正规文法G(S): (1) S → Sa | Ab |b (2) A → Sa 请构造与之等价的DFA。(6分) 答:对应的NFA为:(6分) 状态转换表: a b {F} Φ{S} {S} {S,A} Φ {S,A} {S,A} {S} 五. 构造识别正规语言b*a(bb*a)*b* 最小的DFA(要求写出求解过程)。(15分)答:(1)对应的NFA(5分) a b {0} {1,3} {0} {1,3} Φ{2,3} {2,3} {1,3} {2,3} (5分) 六. 已知文法G(S) : (1) S → ^ | a | (T) (2) T → T,S | S 试:(1)消除文法的左递归;(4分) (2)构造相应的first 和 follow 集合。(6分) 答:(1)消除文法的左递归后文法 G’(S)为: (1) S → ^ | a | (T)

编译原理试题(卷)汇总-编译原理期末试题(卷)(8套含答案解析-大题集)

编译原理考试题及答案汇总 一、选择 1.将编译程序分成若干个“遍”是为了_B__。 A . 提高程序的执行效率 B.使程序的结构更加清晰 C. 利用有限的机器内存并提高机器的执行效率 D.利用有限的机器内存但降低了机器的执行效率 2.正规式 MI 和 M2 等价是指__C__。 A . MI 和 M2 的状态数相等 B.Ml 和 M2 的有向弧条数相等。 C .M1 和 M2 所识别的语言集相等 D. Ml 和 M2 状态数和有向弧条数相等 3.中间代码生成时所依据的是 _C_。 A.语法规则 B.词法规则 C.语义规则 D.等价变换规则 4.后缀式 ab+cd+/可用表达式__B_来表示。 A. a+b/c+d B.(a+b)/(c+d) C. a+b/(c+d) D. a+b+c/d 6.一个编译程序中,不仅包含词法分析,_A____,中间代码生成,代码优化,目标代码生成等五个部分。 A.( ) 语法分析 B.( )文法分析 C.( )语言分析 D.( )解释分析 7.词法分析器用于识别__C___。 A.( ) 字符串 B.( )语句 C.( )单词 D.( )标识符 8.语法分析器则可以发现源程序中的___D__。 A.( ) 语义错误 B.( ) 语法和语义错误 C.( ) 错误并校正 D.( ) 语法错误 9.下面关于解释程序的描述正确的是__B___。 (1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和 FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A.( ) (1)(2) B.( ) (1) C.( ) (1)(2)(3) D.( ) (2)(3) 10.解释程序处理语言时 , 大多数采用的是__B___方法。 A.( ) 源程序命令被逐个直接解释执行 B.( ) 先将源程序转化为中间代码 , 再解释执行 C.( ) 先将源程序解释转化为目标程序 , 再执行 D.( ) 以上方法都可以 11.编译过程中 , 语法分析器的任务就是__B___。 (1) 分析单词是怎样构成的 (2) 分析单词串是如何构成语句和说明的 (3) 分析语句和说明是如何构成程序的 (4) 分析程序的结构 A.( ) (2)(3) B.( ) (2)(3)(4)C.( ) (1)(2)(3) D.( ) (1)(2)(3)(4) 12.编译程序是一种___C__。 A. ( ) 汇编程序 B.( ) 翻译程序 C.( ) 解释程序 D.( ) 目标程序 13.文法 G 所描述的语言是_C____的集合。 A. ( ) 文法 G 的字母表 V 中所有符号组成的符号串 B.( ) 文法 G 的字母表 V 的闭包 V* 中的所有符号串 C.( ) 由文法的开始符号推出的所有终极符串 D. ( ) 由文法的开始符号推出的所有符号串 14.文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 3 型文法是___B__。 A. ( ) 短语文法 B.( ) 正则文法 C.( ) 上下文有关文法 D.( ) 上下文无关文法15.一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组 __D___。 A.( ) 句子 B.( ) 句型 C.( ) 单词 D.( ) 产生式 16.通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括_C____。

四川大学编译原理期末复习总结

一、简答题 1.什么是编译程序 答:编译程序是一种将高级语言程序(源程序)翻译成低级语言(目标程序)的程序。 将高级程序设计语言程序翻译成逻辑上等价的低级语言(汇编语言,机器语言)程序的翻译程序。 2.请写出文法的形式定义 答:一个文法G抽象地表示为四元组 G=(Vn,Vt,P,S) –其中Vn表示非终结符号 –Vt表示终结符号,Vn∪Vt=V(字母表),Vn∩Vt=φ –S是开始符号, –P是产生式,形如:α→β(α∈V+且至少含有一个非终结符号,β∈V*) 3.语法分析阶段的功能是什么 答:在词法分析的基础上,根据语言的语法规则,将单词符号串分解成各类语法短语(例:程序、语句、表达式)。确定整个输入串是否构成语法上正确的程序。 4.局部优化有哪些常用的技术 答:优化技术1—删除公共子表达式 优化技术2—复写传播 优化技术3—删除无用代码 优化技术4—对程序进行代数恒等变换(降低运算强度) 优化技术5—代码外提 优化技术6—强度削弱 优化技术7—删除归纳变量 优化技术简介——对程序进行代数恒等变换(代数简化) 优化技术简介——对程序进行代数恒等变换(合并已知量) 5.编译过程分哪几个阶段 答:逻辑上分五个阶段:词法分析、语法分析、语义分析与中间代码生成、代码优化、目标代码生成。每个阶段把源程序从一种表示变换成另一种表示。 6. 什么是文法 答:文法是描述语言的语法结构的形式规则。是一种工具,它可用于严格定义句子的结构; 用有穷的规则刻划无穷的集合;文法是被用来精确而无歧义地描述语言的句子的构成方式;文法描述语言的时候不考虑语言的含义。 7. 语义分析阶段的功能是什么 答:对语法分析所识别出的各类语法范畴分析其含义,进行初步的翻译(翻译成中间代码); 并对静态语义进行审查。 8.代码优化须遵循哪些原则 答:等价原则:不改变运行结果 有效原则:优化后时间更短,占用空间更少 合算原则:应用较低的代价取得较好的优化效果 9.词法分析阶段的功能是什么 答:

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

一、填空题(每空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 1.编译程序是对高级语言程序的编译执行。X

《编译原理》模拟期末试题汇总 6套,含答案

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

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

编译原理期末复习

编译原理期末复习 鉴于编译原理马上就要期末考试,我将手中集中的一些资料上的题目进行了整理归类,每种类型题目给出了所涉及到的基本知识,然后对每类题目中的第一道例题进行了做法进行了讲解,剩下的例题请给大家作为练习,答案也都给出,希望对大家复习有所帮助,最后由于时间很紧,整理的有些仓促,整理中难免有遗漏或错误,请大家见谅。 注:下面出现的字母中,若无特别说明,小写英文字母为终结符,大写英文字母为非终结符,希腊字母为终结符与非终结符的任意组合。 1、简答题(或者名词解释) 下面涉及到的概念中,加下划线的都是在以往一些试卷中出现的原题,务必掌握。 注:这类题目老师说答案不会超过一百个字,否则写的再多也不给分,有些点到即可,不要重复啰嗦。(1)简述编译程序的概念及其构成 答:1)编译程序:它特指把某种高级程序设计语言翻译成等价的低级程序设计语言的翻译程序。 2)构成: (2)简述词法分析阶段的主要任务(也有可能问语法分析阶段主要任务)答:词法分析的任务是输入源程序,对源程序进行扫描,识别其中的单词符号,把字符串形式的源程序转换成单词符号形式的源程序。 语法分析的主要任务是对输入的单词符号进行语法分析(根据语法规则进行推导或者归约),识别各类语法单位,判断输入是不是语法上正确的程序 (3) 简述编译程序的构造过程(这个大家看看,是对(1)和(2)的综合) 答:1)构造词法分析器:用于输入源程序进行词法分析,输出单词符号; 2)构造语法分析器:对输入的单词符号进行语法分析,识别各类语法单位,判断输入是不是语法上正确的程序 3)构造语义分析和中间代码产生器:按照语义规则对已归约出的语法单位进行语义分析并把它们翻译成中间代码。 4)构造优化器:对中间代码进行优化。 5) 构造目标代码生成器:把中间的代码翻译成目标程序。 6) 构造表格管理程序:登记源程序的各类信息和编译各阶段的进展情况。 7)构造错误处理程序:对出错进行处理。 (4) 说明编译和解释的区别: 1)编译要程序产生目标程序,解释程序是边解释边执行,不产生目标程序; 2)编译程序运行效率高而解释程序便于人机对话。 (5)文法:描述语言语法结构的形式规则,一般用一个四元式表示: G=(V T,V N,S,P),其中V T:终结符集合(非空) V N:非终结符集合(非空),且V T ?V N=? S:文法的开始符号,S?V N P:产生式集合(有限)。

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

编译原理考试题及答案汇总一、选择 1.将编译程序分成若干个“遍”是为了_B__。 A . 提高程序的执行效率 B.使程序的结构更加清晰 C. 利用有限的机器内存并提高机器的执行效率 D.利用有限的机器内存但降低了机器的执行效率 2.正规式 MI 和 M2 等价是指__C__。 A . MI 和 M2 的状态数相等 B.Ml 和 M2 的有向弧条数相等。 C .M1 和 M2 所识别的语言集相等 D. Ml 和 M2 状态数和有向弧条数相等 3.中间代码生成时所依据的是 _C_。 A.语法规则 B.词法规则 C.语义规则 D.等价变换规则 4.后缀式 ab+cd+/可用表达式__B_来表示。 A. a+b/c+d B.(a+b)/(c+d) C. a+b/(c+d) D. a+b+c/d 6.一个编译程序中,不仅包含词法分析,_A____,中间代码生成,代码优化,目标代码生成等五个部分。 A.( ) 语法分析 B.( )文法分析 C.( )语言分析 D.( )解释分析 7.词法分析器用于识别__C___。 A.( ) 字符串 B.( )语句 C.( )单词 D.( )标识符 8.语法分析器则可以发现源程序中的___D__。 A.( ) 语义错误 B.( ) 语法和语义错误 C.( ) 错误并校正 D.( ) 语法错误 9.下面关于解释程序的描述正确的是__B___。 (1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和 FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A.( ) (1)(2) B.( ) (1) C.( ) (1)(2)(3) D.( ) (2)(3) 10.解释程序处理语言时 , 大多数采用的是__B___方法。 A.( ) 源程序命令被逐个直接解释执行 B.( ) 先将源程序转化为中间代码 , 再解释执行 C.( ) 先将源程序解释转化为目标程序 , 再执行 D.( ) 以上方法都可以 11.编译过程中 , 语法分析器的任务就是__B___。 (1) 分析单词是怎样构成的 (2) 分析单词串是如何构成语句和说明的 (3) 分析语句和说明是如何构成程序的 (4) 分析程序的结构 A.( ) (2)(3) B.( ) (2)(3)(4)C.( ) (1)(2)(3) D.( ) (1)(2)(3)(4) 12.编译程序是一种___C__。 A. ( ) 汇编程序 B.( ) 翻译程序 C.( ) 解释程序 D.( ) 目标程序 13.文法 G 所描述的语言是_C____的集合。 A. ( ) 文法 G 的字母表 V 中所有符号组成的符号串 B.( ) 文法 G 的字母表 V 的闭包 V* 中的所有符号串 C.( ) 由文法的开始符号推出的所有终极符串 D. ( ) 由文法的开始符号推出的所有符号串 14.文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 3 型文法是___B__。 A. ( ) 短语文法 B.( ) 正则文法 C.( ) 上下文有关文法 D.( ) 上下文无关文法15.一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组 __D___。 A.( ) 句子 B.( ) 句型 C.( ) 单词 D.( ) 产生式

编译原理试题及答案3

编译原理复习题 一、填空题: 1、编译方式与解释方式的根本区别在于(是否生成目标代码)。 2、对编译程序而言,输入数据是(源程序),输出结果是(目标程序)。 3、如果编译程序生成的目标程序是机器代码程序,则源程序的执行分为两大阶段:(编译阶段)和(运行阶段)。 4、如果编译程序生成的目标程序是汇编语言程序,则源程序的执行分成三个阶段:(编译阶段)、(汇编阶段)和(运行阶段)。 5、自顶向下语法分析方法会遇到的主要问题有(回溯)和((左递归带来的)无限循环)。 6、LL(k)分析法中,第一个L的含义是(从左到右进行分析),第二个L的含义是(每次进行最左推导),“k”的含义是(向输入串中查看K个输入符号)。 7、LL(1)分析法中,第一个L的含义是(从左到右进行分析),第二个L的含义是(每次进行最左推导),“1”的含义是(向输入串中查看1个输入符号)。 8、自顶向下语法分析方法的基本思想是:从(识别符号)出发,不断建立(直接推导),试图构造一个推导序列,最终由它推导出与输入符号相同的(符号串)。 9、自底向上语法分析方法的基本思想是:从待输入的符号串开始,利用文法的规则步步向上进行(直接归约),试图(归约)到文法的(识别符号|开始符号)。 10、LR(0)分析法的名字中,“L”的含义是(从左到右进行分析),“R”的含义是(采用最右推导的逆过程---最左归约),“0”的含义是(向貌似句柄的符号串后查看0个输入符号)。 11、LR(1)分析法的名字中,“L”的含义是(从左到右进行分析),“R”的含义是(采用最右推导的逆过程---最左归约),“1”的含义是(向貌似句柄的符号串后查看1个输入符号)。 12、SLR(1)分析法的名字中,“S”的含义是(简单的),“L”的含义是(从左到右进行分析),“R”的含义是(采用最右推导的逆过程---最左归约),“1”的含义是(向貌似句柄的符号串后查看1个输入符号)。 13、在编译过程中,常见的中间语言形式有(逆波兰表示)、(三元式)、(四元式)和(树形表示)。 14、在编译程序中安排中间代码生成的目的是(便于代码优化)和(便于目标程序的移植)。 15、表达式-a+b*(-c+d)的逆波兰表示为(a-bc-d+*+ )。 16、表达式a+b*(c+d/e)的逆波兰表示为(abcde/+*+ )。 17、表达式a:=a+b*c↑(d/e)/f的逆波兰表示为(aabcde/↑*f/+:= )。 18、文法符号的属性有(继承属性)和(综合属性)两种。 19、一个文法符号的继承属性是通过语法树中它的(兄弟结点与父)结点的相应文法符号的属性来计算的。 20、一个文法符号的综合属性是通过语法树中它的(子)结点的属性来计算的。

郑州大学编译原理试卷及答案(往年试题整合)(2)

二填空题 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) 栈式动态存储分配(2) 堆式动态存储分配 (3) 左(4) 语法分析(5) 目标代码生成 (6) 表格管理 (7) xyz*ab+/+ (8) 继承属性 (9) a+(i-1)*20+j-1 (10) 基本块 8 词法规则通常可以用____正规式________,正规文法、____自动机________描述;语法规则通常用___2型文法___来描述;语义规则通常用__属性文法_____来描述。

9 编译原理的工作过程一般划分为:词法分析、语法分析、语义分析、优化和目标代码生成五个阶段。 1.( )称为规范推导。 2.编译过程可分为(),(),(),()和()五个阶段。 3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是()。 4.从功能上说,程序语言的语句大体可分为()语句和()语句两大类。 5.语法分析器的输入是(),其输出是()。 6.扫描器的任务是从()中识别出一个个()。 7.符号表中的信息栏中登记了每个名字的有关的性质,如()等等。 8.一个过程相应的DISPLAY表的内容为()。 9.一个句型的最左直接短语称为句型的()。 10.常用的两种动态存贮分配办法是()动态分配和()动态分配。 11.一个名字的属性包括( )和( )。 12.常用的参数传递方式有(),()和()。 13.根据优化所涉及的程序范围,可将优化分成为(),()

编译原理期末复习题

3.2是非判断,对下面的述,正确的在述后的括号写T,否则写F。 (1)有穷自动机接受的语言是正则语言。() (2)若r1和r2是Σ上的正规式,则r1|r2也是。() (3)设M是一个NFA,并且L(M)={x,y,z},则M的状态数至少为4个。() (4)令Σ={a,b},则Σ上所有以b为首的字构成的正规集的正规式为b*(a|b)*。() (5)对任何一个NFA M,都存在一个DFA M',使得L(M')=L(M)。() (6)对一个右线性文法G,必存在一个左线性文法G',使得L(G)=L(G'),反之亦然。() 答案 (1) T (2) T (3) F (4) F (5) T (6) T 3.3描述下列各正规表达式所表示的语言。 (1) 0(0|1)*0 (2) ((ε|0)1*)* (3) (0|1)*0(0|1)(0|1) (4) 0*10*10*10* (5) (00|11)*((01|10)(00|11)*(01|10)(00|11)*)* 答案 (1) 以0开头并且以0结尾的,由0和1组成的符号串。 (2) {α|α∈{0,1}*} (3) 由0和1组成的符号串,且从右边开始数第3位为0。 (4) 含3个1的由0和1组成的符号串。{α|α∈{0,1}+,且α中含有3个1 } (5) {α|α∈{0,1}*,α中0和1为偶数} 3.4对于下列语言分别写出它们的正规表达式。 (1) 英文字母组成的所有符号串,要求符号串中顺序包含五个元音。 (2) 英文字母组成的所有符号串,要求符号串中的字母依照词典顺序排列。 (3) Σ={0,1}上的含偶数个1的所有串。 (4) Σ={0,1}上的含奇数个1的所有串。 (5) 具有偶数个0和奇数个1的有0和1组成的符号串的全体。 (6) 不包含子串011的由0和1组成的符号串的全体。 (7) 由0和1组成的符号串,把它看成二进制数,能被3整除的符号串的全体。 答案 (1) 令Letter表示除这五个元音外的其它字母。 ((letter)*A(letter)*E(letter)*I(letter)*O(letter)*U(letter))* (2) A*B*....Z* (3) (0|10*1)* (4) (0|10*1)*1

编译原理试题及答案

参考答案 一、单项选择题(共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 .L 0?L 1?L 2?L 3 B .L 3?L 2?L 1?L 0 C .L 3=L 2?L 1?L 0 D .L 0?L 1?L 2=L 3 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.对编译程序而言,输入数据是(源程序),输出结果是(目标程序)。 三、名词解释题(共5小题,每小题4分,共20分) 1.词法分析 词法分析的主要任务是从左向右扫描每行源程序的符号,按照词法规则 从构成源程序的字符串中识别出一个个具有独立意义的最小语法单位, 并转换成统一的内部表示(token),送给语法分析程序。 2.LL(1)文法 若文法的任何两个产生式A →α | β都满足下面两个条件: (1)FIRST(α) ? FIRST(β ) = φ; (2)若β?* ε,那么FIRST(α) ? FOLLOW( A ) = φ。 我们把满足这两个条件的文法叫做LL(1)文法,其中的第一个L代表从左 向右扫描输入,第二个L表示产生最左推导,1代表在决定分析器的每步 动作时向前看一个输入符号。除了没有公共左因子外,LL(1)文法还有一 些明显的性质,它不是二义的,也不含左递归。 3.语法树 句子的树结构表示法称为语法树(语法分析树或语法推导树)。 给定文法G=(V N,V T,P,S),对于G的任何句型都能构造与之关联的 语法树。这棵树具有下列特征: (1)根节点的标记是开始符号S。 (2)每个节点的标记都是V中的一个符号。 (3)若一棵子树的根节点为A,且其所有直接子孙的标记从左向右的排列 次序为A1A2…A R,那么A→A1A2…A R一定是P中的一条产生式。

(2020年整理)编译原理期末总复习题(含答案).doc

第八节习题一、单项选择题 1、将编译程序分成若干个“遍”是为了 b 。 a.提高程序的执行效率 b.使程序的结构更加清晰 c.利用有限的机器内存并提高机器的执行效率 d.利用有限的机器内存但降低了机器的执行效率 2、构造编译程序应掌握 d 。 a.源程序b.目标语言 c.编译方法d.以上三项都是 3、变量应当 c 。 a.持有左值b.持有右值 c.既持有左值又持有右值d.既不持有左值也不持有右值 4、编译程序绝大多数时间花在 b 上。 a.出错处理b.词法分析 c.目标代码生成d.管理表格 5、 d 不可能是目标代码。 a.汇编指令代码b.可重定位指令代码 c.绝对指令代码d.中间代码 6、使用 a 可以定义一个程序的意义。 a.语义规则b.词法规则 c.产生规则d.词法规则 7、词法分析器的输入是 a 。 a.单词符号串b.源程序 c.语法单位d.目标程序 8、中间代码生成时所遵循的是- d 。 a.语法规则b.词法规则 c.语义规则d.等价变换规则 9、编译程序是对 d 。 a.汇编程序的翻译b.高级语言程序的解释执行 c.机器语言的执行d.高级语言的翻译 10、语法分析应遵循 b 。 a.语义规则b.语法规则 c.构词规则d.等价变换规则 解答 1、将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选b。 2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选d。 3、对编译而言,变量既持有左值又持有右值,故选c。 4、编译程序打交道最多的就是各种表格,因此选d。 5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,因此不是目标代码的只能选d。 6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。因此选a。 7、b 8、c 9、d 10、c 二、多项选择题

编译原理考试试题与答案(汇总)

《编译原理》考试试题及答案(汇总) 一、是非题(请在括号,正确的划√,错误的划×)(每个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.( ) 代码外提

编译原理试题及答案——加强版

编译原理试题及答案 <高级版> 一、对于文法 G[S] : S → 1A | 0B | ε A → 0S | 1AA B → 1S | 0BB ⑴ (3 分 ) 请写出三个关于 G[S] 的句子; ⑵ (4 分 ) 符号串 11A0S 是否为 G [S] 的句型?试证明你的结论。 ⑶ (3 分 ) 试画出 001B 关于 G [S] 的语法树。 二、请构造一个文法,使其产生这样的表达式 E :表达式中只含有双目运算符 + 、 * ,且 + 的优先级高于 * , + 采用右结合, * 采用左结合,运算对象只有标识符 i ,可以用括号改变运算符优先级。要求给出该文法的形式化描述。 三、设有语言 L={ α | α∈ {0,1} + ,且α不以 0 开头,但以 00 结尾 } 。 ⑴试写出描述 L 的正规表达式; ⑵构造识别 L 的 DFA (要求给出详细过程,并画出构造过程中的 NDFA 、 DFA 的状态转换图,以及 DFA 的形式化描述 ) 。 四、给定文法 G[S] : S → AB A → a B | bS | c B → AS | d ⑴ (6 分 ) 请给出每一个产生式右部的 First 集;

⑵ (3 分 ) 请给出每一个非终结符号的 Follow 集; ⑶ (8 分 ) 请构造该文法的 LL(1) 分析表; ⑷ (8 分 ) 什么是 LL(1) 文法?该文法是 LL(1) 文法吗?为什么? 五、给定文法 G[S] : S → SaA|a A → AbS|b ⑴请构造该文法的以 LR(0) 项目集为状态的识别规范句型活前缀的 DFA 。 ⑵请构造该文法的 LR(0) 分析表。 ⑶什么是 LR(0) 文法?该文法是 LR(0) 文法吗?为什么? ⑷什么是 SLR(1) 文法?该文法是 SLR(1) 文法吗?为什么? 六、给定下列语句: if a+b>c then x := a*(b-c) + (b*c-d)/e ⑴写出其等价的逆波兰表示; ⑵写出其等价的四元式序列。 七、已知下列 C 语言程序: int * f() { int a = 100; return &a; } main()

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

一. 填空题(每空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 . 该句子有两棵不同的语法树

《编译原理》期末考试复习题

《编译原理》期末考试复习题 一、是非题(请在括号内,正确的划√,错误的划×)(每个2分,共20分) ×1.计算机高级语言翻译成低级语言只有解释一种方式。() ×2.在编译中进行语法检查的目的是为了发现程序中所有错误。() √3.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。 () ×4.正则文法其产生式为 A->a , A->Bb, A,B∈VN , a 、b∈VT 。 () √5.每个文法都能改写为 LL(1) 文法。 () √6.递归下降法允许任一非终极符是直接左递归的。 () ×7.算符优先关系表不一定存在对应的优先函数。 () ×8.自底而上语法分析方法的主要问题是候选式的选择。 () ×9.LR 法是自顶向下语法分析方法。 () ×10.简单优先文法允许任意两个产生式具有相同右部。 () 三、填空题(每空1分,共10分) 1.编译程序的工作过程一般可以划分为词法分析,语法分析,语义分析,中间代码生成,代码优化等几个基本阶段,同时还会伴有__ ___和 ___ _。 表格管理出错处理_ 2.若源程序是用高级语言编写的,__ __是机器语言程序或汇编程序,则其翻译程序称为 __ __ 。 _目标程序_编译程序 3.编译方式与解释方式的根本区别在于__ __。 是否生成目标代码_ 4.对编译程序而言,输入数据是__ __, 输出结果是__ ___。 _源程序目标程序

5.产生式是用于定义__ __的一种书写规则。 _语法成分 6.语法分析最常用的两类方法是___ __和__ __分析法。 自上而下_自下而上 四、简答题(20分) 1. 什么是句子?什么是语言 ? 答:(1)设G是一个给定的文法,S是文法的开始符号,如果S x(其中x∈VT*),则称x是文法的一个句子。 (2)设G[S]是给定文法,则由文法G所定义的语言L(G)可描述为:L(G)={x│S x,x∈VT*} 。 一、是非题(请在括号内,正确的划√,错误的划×)(每个2分,共20分) ×1.对于数据空间的存贮分配,FORTRAN采用动态贮存分配策略。() ×2.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。() √3.递归下降分析法是自顶向上分析方法。() ×4.产生式是用于定义词法成分的一种书写规则。() √5.LR 法是自顶向下语法分析方法。() √6.在SLR (1 )分析法的名称中,S的含义是简单的。() ×7.综合属性是用于“ 自上而下” 传递信息。() ×8.符号表中的信息栏中登记了每个名字的属性和特征等有关信息,如类型、种属、所占单元大小、地址等等。() ×9.程序语言的语言处理程序是一种应用软件。() ×10.解释程序适用于COBOL 和FORTRAN 语言。() 三、填空题(每空1分,共10分) 1.一个句型中的最左简单短语称为该句型的___句柄__。

相关文档
相关文档 最新文档