编译原理复习题-给学生(简) 下载本文

《编译原理》复习题

一、单项选择题

1.构造编译程序应掌握 。D

a. 源程序 b. 目标语言 c. 编译方法 d. 以上三项都是 2.编译程序绝大多数时间花在 上。D

a. 出错处理 b. 词法分析 c. 目标代码生成 d. 表格管理 3.DFA M(见图1-1)接受的字集为 。D

a. 以0开头的二进制数组成的集合 0b. 以0结尾的二进制数组成的集合

X0Y1c. 含奇数个0的二进制数组成的集合 图1-1

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

4. -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*+- 5.在规范归约中,用 来刻画可归约串。 B

a. 直接短语 b. 句柄

c. 最左素短语 d. 素短语

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

a. 归约 b. 移进 c. 接受 d. 待约 7.中间代码生成时所依据的是 。C

a. 语法规则 b. 词法规则 c. 语义规则 d. 等价变换规则

8.有文法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 9.如果文法G是无二义的,则它的任何句子α 。 A

1

《编译原理》复习题

a. 最左推导和最右推导对应的语法树必定相同 b. 最左推导和最右推导对应的语法树可能不同 c. 最左推导和最右推导必定相同

d. 可能存在两个不同的最左推导,但它们对应的语法树相同 10.下列动作中,不是自下而上分析动作的是: 。B a. 移进 b. 展开

c. 接受 d. 报错

11.编译程序是对 。D

a. 汇编程序的翻译 b. 高级语言程序的解释执行 c. 机器语言的执行 d. 高级语言的翻译 12.词法分析器的输出结果是 。C

a. 单词的种别编码 b. 单词在符号表中的位置 c. 单词的种别编码和自身值 d. 单词自身值 13.正规式M1和M2等价是指 。C

a. M1和M2的状态数相等 b. M1和M2的有向边条数相等 c. M1和M2所识别的语言集相等 d. M1和M2状态数和有向边条数相等

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

a. 直接短语 b. 句柄 c. 最左素短语 d. 素短语 15.若a为终结符,则A→α·aβ为 项目。B

a. 归约 b. 移进

c. 接受

d. 待约

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

a. 语法规则 b. 词法规则 c. 语义规则 d. 等价变换规则 17.文法G:S→xSx|y所识别的语言是 。C a. xyx b. (xyx)*

c. xnyxn (n≥0) d. x*yx*

18.如果文法G是无二义的,则它的任何句子α 。 A a. 最左推导和最右推导对应的语法树必定相同 b. 最左推导和最右推导对应的语法树可能不同 c. 最左推导和最右推导必定相同

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

2

《编译原理》复习题

19.下列动作中,不是自上而下分析动作的是: 。C a. 匹配 b. 展开

c. 移进 d. 报错

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

a. 单词的种别编码 b. 单词在符号表中的位置

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

21. -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*+- 22.在规范归约中,用 来刻画可归约串。 B a. 直接短语 b. 句柄

c. 最左素短语 d. 素短语

23.若B为非终结符,则A→α· 为 项目。A a. 归约 b. 移进

c. 接受

d. 待约

24.文法G:S→xSx| xS|y所识别的语言是 。 A a. xmyxn(m≥n≥0) b. (xyx)*

c. xnyxn(n≥0) d. x*yx*

25.有文法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 26.间接三元式表示法的优点为 。 A a. 采用间接码表,便于优化处理 b. 节省存储空间,不便于表的修改 c. 便于优化处理,节省存储空间 d. 节省存储空间,不便于优化处理

3

《编译原理》复习题

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

a. 匹配

b. 展开

c. 接受 d. 报错

28.同正规式(a|b)+等价的正规式是______B___________。

A.(a|b)* B.(a|b)(a|b)* C.(ab)*(ab) D.(a|b)|(a|b)* 29.称有限自动机A1和A2等价是指_______D________。 A.A1和A2都是定义在一个字母表上的有限自动机 B.A1和A2状态数和有向边数相等 C.A1和A2状态数或有向边数相等 D.A1和A2所能识别的字符串集合相等

30.由文法的开始符号出发经过若干步(包括0步)推导产生的文法符号序列称为______B________。 A.语言 B.句型 C.句子 D.句柄 31.在自上而下的语法分析中,应从 C 开始分析。 A.句型

B.句子

C.文法开始符号

D.句柄

32.一个文法G,若________C____________,则称它是LL(1)文法。 A.G中不含左递归 B.G无二义性 C.G的LL(1)分析表中不含多重定义的条目 D.G中产生式不含左公因子 33.在规范归约中,用______B______来刻画可归约串。 A.直接短语 B.句柄 C.素短语 D.短语 34.若a为终结符,则A→α·aβ为_______B______项目。 A.归约 B.移进 C.接受 D.待约 35.中间代码生成时所依据的是 C 。

A.词法规则 B.语法规则 C.语义规则 D.等价变换规则 36.文法G[S]及其语法制导翻译定义如下: 产生式 S’ → S

语义动作 print(S.num) S.num = L.num +1 S.num = 0

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

S → (L)

S → a

L →L(1), S

L →S

L.num = S.num

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

4

《编译原理》复习题

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

37.四元式之间的联系是通过 _______B____________实现的。 A.指示器 B.临时变量 C.符号表 D.程序变量 38.将编译程序分成若干“遍”,是为了( B )。

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

39.一个编译程序在编译时,大多数时间花在( D )上。 A.出错处理 B.词法分析 C.目标代码生成 D.表格管理及处理

40. 下列符号串不可以由符号集?={a,b}上的正闭包运算产生的是:(A ) A. ε B. a C. aa D. ab 41.词法分析器的输出是:( C )

A.单词在符号表中的位置 B.单词的自身值 C.单词的自身值和单词的种类码 D.单词的种类码 42. 两个DFA等价是指:( D ) A. 这两个DFA的状态数相同

B. 这两个DFA的状态数和有向弧条数都相等 C. 这两个DFA的有向弧条数相等 D. 这两个DFA接受的语言相同

43.生成中间代码时所依据的是( C )。

A.语法规则 B.词法规则 C.语义规则 D.等价变换规则 44.表达式(┐a∨b)∧(c∨d)的逆波兰表示为(B )。 A.┐ab∨∧cd∨ B.a┐b∨cd∨∧ C.ab∨┐cd∨∧ D.a┐b∨∧cd∨

45.有文法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 46.表达式a+b+c+d的逆波兰表示为( B )。

5

《编译原理》复习题

A.a+bc+d+ B.ab+c+d+ C.ab+cd++ D.abc+d++ 47. 文法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

48.若a为终结符,则A→α. aβ为( B )。 A.归约项目 B.移进项目 C.待约项目 D.接受项目 49.若B为非终结符,则A→α. Bβ为( C )。 A.归约项目 B.移进项目 C.待约项目 D.接受项目 50. 项目A→α. 为( A )。

A.归约项目 B.移进项目 C.待约项目 D.接受项目 51. 语法分析器的输入是:( A )

A. Token序列 B. 源程序 C. 目标程序 D. 符号表

52. 在LR(0)的Action表中,如果某行中存在标记为“rj”的栏,则:( A ) A. 该行必定填满“rj” B. 该行未必填满“rj” C. 其他行可能也有“rj” D. goto表中也可能有“rj” 53. LR分析过程中栈内存储的是( A )。 A. 活前缀 B. 前缀 C. 归约活前缀 D. 项目

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

A.xxy* B.(xxy)* C.xx*yx D.(xx)*y 55.若状态k含有项目“A→α.”,对任意非终结符a,都用规则“A →α”归约的语法分析方法是( BA.LALR分析法 B.LR(0)分析法 C.LR(1)分析法 D.SLR(1)分析法

56.在编译过程中,如果遇到错误应该( C )。 A. 把错误理解成局部的错误

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

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

D. 当发现错误时立即停止编译,待用户改正错误后再继续编译 57.将编译程序分成若干“遍”,是为了( B )

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

58.下列符号串不可以由符号集?={a,b}上的正闭包运算产生的是:( A ) A. ε B. a

。6

) 《编译原理》复习题

C. aa D. ab 59.表达式(┐a∨b)∧(e∨f)的逆波兰表示为( B )。 A.┐ab∨∧ef∨ B.a┐b∨ef∨∧ C.ab∨┐ef∨∧ D.a┐b∨∧ef∨

60.有文法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 61.表达式a+b+c的逆波兰表示为( B )。 A.a+bc+ B.ab+c+ C.+abc+ D.abc++ 62. 文法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

63. 在SLR(1)的Action表中,如果某行中存在标记为“rj”的栏,则:( B ) A. 该行必定填满“rj” B. 该行未必填满“rj” C. 其他行可能也有“rj” D. goto表中也可能有“rj”

64. 一个( D )指明了在LR分析过程中的某个时刻所能看到产生式多大一部分。 A. 活前缀 B. 前缀 C. 归约活前缀 D. 项目

65.文法G:S → xS | y 所识别的语言是( D )。 A.xy* B.(xy)* C.xx*yx D.x*y 66.若状态k含有项目“A→α.”,且仅当输入符号a∈FOLLOW(A)时,才用规则“A →α”归约的语法分析方法是( D )。

A.LALR分析法 B.LR(0)分析法 C.LR(1)分析法 D.SLR(1)分析法 67.设有文法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)

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

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

7

《编译原理》复习题

69.编译程序的语法分析器必须输出的信息是( A ) A.语法错误信息 B.语法规则信息 C.语法分析过程 D.语句序列 70.下列项目中为可移进项目的是( C )。

A.E′→E . B.L→. C.L→-.L D.F→L*F. 71.有一语法指导定义如下: 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 72.同正规式(a|b)*等价的正规式为( D ) A.(a|b)+ B.a*|b* C.(ab)* D.(a*|b*)+ 73.词法分析器的加工对象是( C ) A.中间代码 B.单词 C.源程序 D.元程序 74.在自下而上的语法分析中,应从( B )开始分析。

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

75.赋值语句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* +--:= 76.设有文法G[T]: T→T*F|F F→F↑P|P P→(T)|a

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

A.(T*F) B. T*F C. P D. P↑(T*F)

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

A.终结符 B.非终结符 C.终结符或非终结符 D.终结符和结束符$ 78.下列项目中为可归约项目的是( B )。

A.E′→.E B.L→. C.L→-.L D.F→L*.F 79.有一语法指导定义如下,其中+表示符号连接运算: 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 80.同正规式(a|b)*等价的正规式为( D ) A.(a|b)+ B.a*|b* C.(ab)* D.(a*|b*)+

共 4 页 第 1 页

81.词法分析器的加工对象是( C )

A.中间代码 B.单词 C.源程序 D.元程序

8

《编译原理》复习题

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

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

83.赋值语句X:=-(a+b)/(c-d)-(a+b*c)的逆波兰表示是( C ) E. Xab+cd-/-bc*a+-:= F. Xab+/cd-bc*a+--:= G. Xab+-cd-/ a bc* +-:= H. Xab+cd-/abc* +--:= 84.编译程序不能检查、处理的错误是程序中的_______B_________。

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

85.在LR(0)的ACTION子表中,如果某一行中有标记为“rj”的栏,则_______C__________。A.该行既有rj又有Sj B.其它行也有rj C.该行一定填满rj D.该行未填满rj

86.同正规式(a|b)+等价的正规式是_________B________________。

A.(a|b)* B.(a|b)(a|b)* C.(ab)*(ab) D.(a|b)|(a|b)* 87.在规范归约中,用______B______来刻画可归约串。

A.直接短语 B.句柄 C.素短语 D.短语 88.若a为终结符,则A→α·aβ为_______B______项目。 A.归约 B.移进 C.接受 D.待约 89.一个文法G,若________C____________,则称它是LL(1)文法。 A.G中不含左递归 B.G无二义性 C.G的LL(1)分析表中不含多重定义的条目 D.G中产生式不含左公因子 90.LR分析器的核心部分是一张分析表,该表由_______D___________组成。

A.ACTION表 B.GOTO表 C.预测分析表 D.ACTION表和GOTO表 91.构造编译程序应该掌握_______D__________。

A.源程序 B.目标语言 C.编译方法 D.以上三项都是 92.在递归子程序方法中,若文法存在左递归,则会使分析过程产生___D__________。 A.回溯 B.非法调用 C.有限次调用 D.无限循环 93.最左简单子树的叶结点,自左至右排列组成句型的________C____________。 A.短语 B.句型 C.句柄 D.间接短语

94.如果一个正规式所代表的集合是无穷的,则它必含有的运算是__________C___________。 A.连接运算“· ” B.或运算“|” C.闭包运算“* ” D.括号“(”和“)” 95.同正规式a*b*等价的文法是________C___________。

A.G1:S→aS|bS|ε B.G2:S→aSb|ε C.G3:S→ aS|Sb|ε D.G4: S→ abS|ε

9

《编译原理》复习题

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

97.四元式之间的联系是通过 _______B____________实现的。 A.指示器 B.临时变量 C.符号表 D.程序变量 98.编译程序的语法分析器必须输出的信息是________A____________。

A.语法错误信息 B.语法规则信息 C.语法分析过程 D.语句序列

99.LL(1)分析法中“1”的含义是在输入串中查看一个输入符号,其目的是_______C___________。 A.确定最左推导 B.确定句柄 C.确定使用哪一个产生式进行展开 D.确定是否推导 100.称正规式R1和R2 等价是指__________C_______________。 A.R1和R2都是定义在同一个字母表上的正规式 B.R1和R2使用的运算符相同 C.R1和R2代表同一个正规集 D.R1和R2代表不同的正规集

二、填空题 概述部分:

1.编译程序的开发常常采用自编译、 交叉编译 、 自展 和移植等技术实现。 2.解释程序和编译程序的区别在于 是否生成目标程序 。

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

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

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

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

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

10

《编译原理》复习题

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分析法。

11

《编译原理》复习题

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]的____

*S?x,x?VT句型__,若x仅由终结符号组成,即,则称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,#} 。

12

《编译原理》复习题

语义处理部分:

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

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

4.编译过程中,常见的中间语言形式有 逆波兰表示法 、 抽象语法树 、 三元式 、 四元式 。 5.词法分析器的输入是 源程序字符串 ,输出结构是 二元式(单词种别, 单词自身的值) 。 6.文法符号的属性有两种,一种称为 继承属性 ,另一种称为 综合属性 。 7.四元式之间的联系是通过 临时变量 实现的。 8.在属性文法中,终结符只有____综合 属性。

9.编译过程中,常见的中间语言形式 有 逆波兰式 、 抽象语法树 、 三元式 、 四元式 。 10.语法制导翻译的方法就是为每个产生式配上一个 翻译子程序(语义动作或语义子程序) ,并在语法分析的同时执行它们。

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

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.无论是三元式表示还是间接三元式表示的中间代码,其三元式在三元式表中的位置一旦确定就很难改变。( √ )

13

《编译原理》复习题

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. 语义分析

14

)《编译原理》复习题

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 是(ABE )。

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 )

15

《编译原理》复习题

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(aa)*bb(bb)*a(aa)* 的NFA。 解:

256aabbaaXa1b3b4aY

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

3aaX?1?2bY??a4b

2.令文法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

16

《编译原理》复习题

3.给出字母表Σ={a,b}上的同时只有奇数个a和奇数个b的所有串的集合的正规文法; 解: G[S]:S→aA|bB A→aS|bC|b B→bS|aC|a C→bA|aB|ε 4.给定文法:S→(L) | a L→L,S | S

请书写语义规则,求输出句子中每一个a的括号嵌套深度。 解:

用继承属性depth表示嵌套深度,则 S’ → S S.depth = 0 S → (L) L.depth = S.depth + 1 S → a print(S.depth) L → L(1), S L(1).depth = L.depth; S.depth = L.depth L → S S.depth = L.depth

5. 表达式a*b-c-d$e$f-g-h*i中,运算符的优先级由高到低依次为-、*、$,且均为右结合,请写出相应的后缀式。

解: abcd- -*efgh- - i*$$

6.判断文法G[S]: S → BA

A → BS | d B → aA| bS | c 是否为LL(1)文法.

解:对于该文法求其FIRST集如下:

FIRST(S) = {a, b, c}; FIRST(A) = {a, b, c, d}; FIRST(B) = {a, b, c}。 求其FOLLOW集如下:

FOLLOW(S) = {a, b, c, d, #}; FOLLOW(A) = {a, b, c, d, #}; FOLLOW(B) = {a, b, c, d, #}。 由A → BS | d 得:

FIRST(BS) ∩ FIRST(‘d’) = {a, b, c} ∩ {d} = Φ 由B → aA| bS | c 得

FIRST(aA) ∩ FIRST(bS) ∩ FIRST(c) = {a} ∩{b}∩ {c} =Φ

由于文法G[S]不存在形如β→ε的产生式,故无需求解形如FIRST(α) ∩ FOLLOW(A)的值,也即文法G[S]是一个LL(1)文法。

7.对于文法G[E]: E→E+T | T

T→T+P | P P→(E) | i

写出句型P+T+(E+i)的所有短语、直接短语、句柄。 解:短语:P、P+T、i、E+i、(E+i )、P+T+(E+i );//T+(E+i ) 直接短语:P、i; 句柄:P;

8.已知文法G[A]: A→aABl|a

17

《编译原理》复习题

B→Bb|d

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

A′→ABl | ε B→dB′

B′→bB′| ε

9.将下面的语句翻译成四元式序列: if (x>y) m= 1; else m=0;

解:1 (j>,x,y,3)

2 (j,_,_,5) 3 (=,1,_,m) 4 (j,_,_,6) 5 (=,0,_,m) 6:

10.将以下DFA 最小化。(8分)

2bXa1a?Y

解:

a0b1

11.设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′。(12分)

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

aabbXYb

18

《编译原理》复习题

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

I Ia Ib {x} {x,y} {y} {y} — {x,y} {x,y} {x,y} {x,y}

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

f 字符 状态 a b 0 2 1 1 — 2 2 2 2

M′=({0,1,2},{a,b},f,0,{1,2}),

M′状态转换图如下图所示。

a 02a, b b

b 1

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

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

G[A]: A→aABl|a

B→Bb|d

解:拓广文法 (0)S→A

(1)A→aABl (2)A→a (3)B→Bb (4)B→d

19

《编译原理》复习题

I0:S→.A I1:S→A. A→.aABl A→.a a I2:A→a.ABl I3: A→a. A A→aA.Bl d A→.aABl B→.Bb I4:B→d. A→.a B→.d B a I5: l I6: A→aAB.l A→aABl. B→B.b b I7: B→Bb. First(A)={a}follow(A)={#,d} First(B)={d}follow(B)={l} SLR(1)分析表如下: a b d l # A B 0 S2 1 1 ACC 2 S2 R2 R2 3 3 S4 5 4 R4 5 S7 S6 6 R1 R1 7 R3 13.将下面的语句翻译成四元式序列:(7分) if (x>y) m= 1; else m=x+y;

解:1 (j>,x,y,3)

2 (j,_,_,5) 3 (=,1,_,m) 4 (j,_,_,7) 5 (+,x,y,T1) 6 (=, T1,_,m) 7:

14. 试构造下述文法的LL(1)分析表。(15分)

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

L→L,S|S

解:消除左递归:

20

《编译原理》复习题

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’) = {)}

LL(1)分析表 S L L’ ( S ? (L) L ? SL’ ) L’ ? ε a S ? a L ? SL’ , L’ ? ,SL’ #

15.判断文法G[S]: S → BA A → BS | d B → aA| bS | c 是否为LL(1)文法.

解:对于该文法求其FIRST集如下:

FIRST(S) = {a, b, c}; FIRST(A) = {a, b, c, d}; FIRST(B) = {a, b, c}。 求其FOLLOW集如下:

FOLLOW(S) = {a, b, c, d, #}; FOLLOW(A) = {a, b, c, d, #}; FOLLOW(B) = {a, b, c, d, #}。 由A → BS | d 得:

FIRST(BS) ∩ FIRST(‘d’) = {a, b, c} ∩ {d} = Φ 由B → aA| bS | c 得

FIRST(aA) ∩ FIRST(bS) ∩ FIRST(c) = {a} ∩{b}∩ {c} =Φ

由于文法G[S]不存在形如β→ε的产生式,故无需求解形如FIRST(α) ∩ FOLLOW(A)的值,也即文法G[S]是一个LL(1)文法。 16.对于文法G[E]: E→E+T | T

T→T+P | P P→(E) | i

写出句型P+T+(E+i)的所有短语、直接短语、句柄。 解:短语:P、i、E+i、(E+i )、T+(E+i )、P+T+(E+i ); 直接短语:P、i; 句柄:P;

17.已知文法G[S]: S→aSbS|bSaS|ε 试证明G[S]是二义文法

21

《编译原理》复习题

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

S?aSbS?abS?abaSbS?ababS?abab S?aSbS?abSaSbS?abaSbS?ababS?abab

18.将下面的语句翻译成四元式序列: while(a

if (c>d) x=y+z

解:100 (j<,a,b,102)

101 (j,_,_,107) 102 (j>,c,d,104) 103 (j,_,_,106) 104 (+,y ,z ,t) 105 (=,t ,_ ,x) 106 (j,_,_,100) 107:

19.构造正规表达式a(aa)*bb(bb)*a 的最小化的确定有限自动机M′。 解: 先画出正规式相应的NFA M状态图,如下图所示。

2 5

a a b b

a b b a X 1 3 4

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

I {x} {1} {2} {3} {4} {5} {Y} Y Ia {1} {2} {1} - {Y} - - Ib - {3} - {4} {5} {4} -

将状态分为终态集{Y}和非终态集{X,1,2,3,4,5} 因为{X,1,2,3,4,5}a={1,2,1,_,Y,_} 所以非终态集分为{X,1,2},{3,5},{4} 因为{X,1,2}b={_,3,_},所以分为

最后得到集合{X,2},{1},{3,5},{4},{Y}重新命名为1,2,3,4,5得到最小化的DFA M′状态转换矩阵和

22

《编译原理》复习题

状态转换图如下图所示。 I Ia Ib 1 2 _ 2 1 3 a b b a 3 - 4 1 a 2 3 4 5 4 5 3 b 5 - _

(注意:本题由于集合的命名和先后顺序不同,可能最终结果不同。) 20.试构造下述文法的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

I0:S→.A A I1:S→A. A→.aABl A→.a a I2:A→a.ABl Bl A→a. A I3:A→aA.B→.Bb d I4:B→d. A→.aABl B→.d A→.a B a I5: l I6: A→aAB.l A→aABl. B→B.b b I7: B→Bb.

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

SLR(1)分析表如下:

23

《编译原理》复习题

a 0 1 2 3 4 5 6 7 S2 S2 b S7 ACTION d l R4 S6 R3 # ACC R2 R1 A 1 3 GOTO B 5 R2 S4 R1 21.画出编译程序的总体结构图,简述各部分的主要功能。

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

表词法分析器单词符号语法分析器语法单位语义分析与中间代码生成器出格错管四元式优化段四元式目标代码生成器目标代码处理理 (1)词法分析器,又称扫描器,它接受输入的源程序,对源程序进行词法分析,识别出一个个单词符号,其输出结果是二元式(单词种别,单词自身的值)流。

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

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

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

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

24

《编译原理》复习题

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

S → (L) | aS | a L → L, S | S

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

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

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

S ( L ) L , S S ( L ) S a

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

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

S→ ε| aA|bB A→ b| bS| aAA B→ a| aS| bBB

24.分别给出表达式 –(a*(b-c))+d 的逆波兰表示和四元式表示。 解:(1)逆波兰式: abc-*@d+ 其中使用@代表一目减运算 (2)四元式: ① (-, b, c, T1)

25

《编译原理》复习题

② (*, a, T1, T2) ③ (@, T2, _, T3) ④ (+, T3, d, T4)

25.把下列语句翻译为四元式序列: while (A > B) if (C > D)

X = Y * Z

else

X = Y + Z 解:

(1) (j>, A, B, 3) (2) (j, _, _, 11) (3) (j>, C, D, 5) (4) (j, _, _, 8) (5) (*, Y, Z, T1) (6) (=, T1, _, X) (7) (j, _, _, 1) (8) (+, Y, Z, T2) (9) (=, T2, _, X) (10) (j, _, _, 1) (11)

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

(2)

①NFA (2分)

0 X ε 0 ε 1 1 2

0 ε 3 0 ε Y 0 26

《编译原理》复习题

②子集法确定化

I {X, 0, 1, 3, Y} {0, 1, 3, Y} {2} {1, 3, Y} 重新命名状态,即得:

S 1 2 3 4 ③ 最小化

首先分为终态集和非终态集 {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如下图所示:

0 1 0 0

27.已知文法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’ | ε

27

I0 {0, 1, 3, Y} {0, 1, 3, Y} {1, 3, Y} {1, 3, Y} I1 {2} {2} - {2} 0 2 2 4 4 1 3 3 - 3 1

《编译原理》复习题

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’) = {*, #}

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

* + a # S S→*aPS’ S→aPS’ S’ S’→ *aP S’→ ε P P→+aP’ P’ P’→ε P’→P P’→ε 28.已知文法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:

28

《编译原理》复习题

I4: S’→ aS? S a I0: S’→ ?S S→ ?aS S→ ?bS S→ ?a b I2: S→ a?S S→ ?aS S→ ?bS S→ ?a S→ a? a S I1: S’→ S? b a I5: S’→ bS? I3: S→ b?S S→ ?aS S→ ?bS S→ ?a S b (2)在状态I2存在“移近-归约”冲突,因此该文法不是LR(0)文法。

计算S的FOLLOW集合: FOLLOW(S)= {#}

I2中的冲突用FOLLOW集合可以解决,所以该文法是SLR(1)文法。 构造SLR(1)分析表如下:

状态 0 1 2 3 4 5

29.将下图所示的非确定有限自动机(NFA)变换成等价的确定有限自动机(DFA)。其中,X为初态,Y为终态。

ACTION a s2 s2 s2 b s3 s3 s3 # acc r3 r1 r2 GOTO S 1 4 5 29

《编译原理》复习题

b2bab3b4baYaaX1??a?

【解】 用子集法将NFA确定化,如图所示。

IIaIbSab{X}{1}{3}012{1}{2,3,Y}{3,Y}134{3}—{3,4}重新命名2—5{2,3,Y}{2,3,Y}{2,3,4,Y}336{3,Y}{2,3,Y]{3,4}435{3,4}{3,4}{3,4,Y}557{2,3,4,Y}{2,3,4,Y}{2,3,4,Y}666{3,4,Y}{2,3,4,Y}{3,4,Y}767确定化的DFA如下图所示:

a3aaba1ba604bb2bab5b7ab30.

对正规式(a|b)*abb构造其等价的NFA。 【解】

30

《编译原理》复习题

31. 下面的文法产生0和1的串,即二进制的正整数,请给出决定每个二进制数的值(十进制形式)的语法制导定义。

【解】定义值属性为.val,翻译方案如下: B ? B1 0 { B.val = B1.val ? 2 } B ? B1 1 { B.val = B1.val ? 2 + 1 } B ? 1 { B.val = 1 }

B ? 0 { B.val = 0 }

32.把算术表达式?(a + b) ? (c + d) + (e+ f) 翻译成等价的四元式序列(序号从0开始)。 【解】

0(+,a, b ,T1)

1(uminus,T1,-,T2) 2(+,c, d , T3) 3(*,T2,T3,T4) 4(+,e,f,T5) 5(+,T4,T5,T6)

33.设有文法G[S]:

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

试给出句子(a,a,a)的最左推导。 【解】(1) (a,a,a)的最左推导

S=>(T) =>(T,S) =>( T,S,S) =>( S,S,S) =>(a,S,S) =>(a,a,S) =>(a,a,a)

34.已知文法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)文法

31

《编译原理》复习题

2)预测分析表: S L

35.文法

S ? A a | b A c | d c | b d a A ? d

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

I1 S ? .A a S ? .b A c A a S ? A .a S ? A a . S ? .d c I2 I5 S ? .b d a A ? .d c S ? b A .c S ? b A c . A S ? b .A c b I0 I6 I9 S ? b .d a A ? .d d S ? b d .a I3 S ? b d a . a d A ? d . I10 S ? d .c I7 A ? d . c S ? d c . I4 I8 ( S→ ( L L→ S , L a S→ a L→ S , L , } L → ) # Follow(S)={#}

Follow(A)={a,c}

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

36.将下图所示的确定有限自动机(DFA)最小化。其中,X为初态,Y为终态。

aaXb21ba3abYb

【解】 先划分为终态集{Y}和非终态集I={X,1,2,3}

X面对输入符号b时下一状态属于I,而1,2,3面对输入符号b时下一状态属于{Y},故划分为{X}、{1,2,3} 非终态2和非终态3面对输入符号a的下一状态相同,而1不同,即最简状态{X}、{1}、{2,3}、{Y}。按顺序重新命名为0、1、2、3,则得到最简DFA,

32

《编译原理》复习题

a0ab1a2b3b

37.请画出识别无符号十进制整数的状态转换图 【解】

1-9 0-9 1 2 ?(其它) 3 0

38.设有文法G[S]:

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

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

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

39.程序的文法如下:

P → D

D → D;D | id : T | proc id; D; S

写一语法制导定义,打印该程序一共声明了多少个id 【解】 属性num表示id个数 P → D print(D.num) D → D(1);D(2) D.num = D(1).num + D(2).num D → id : T D.num = 1 D → proc id; D(1); S D.num = D(1).num + 1

例:proc id; proc id; id : T; S; S(从语法树分析入手) (注意:本例只是帮助学生理解题意,不是答案部分)

33

《编译原理》复习题

P D procid ; D ; S procid ; D ; id : T

40.把下列语句翻译为四元式序列(四元式序号从1开始): while (A > B) if (C > D)

X = Y * Z

else

X = Y + Z 【解】(1) (j>, A, B, 3) (2) (j, _, _, 11) (3) (j>, C, D, 5) (4) (j, _, _, 8) (5) (*, Y, Z, T1) (6) (=, T1, _, X) (7) (j, _, _, 1) (8) (+, Y, Z, T2) (9) (=, T2, _, X) (10) (j, _, _, 1) (11)

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

T ? int | real L ? id R

R ? , id R | ?

S 34

《编译原理》复习题

【解】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(1)文法,LL(1)分析表如下: D T L R int D ? TL T ? int real D ? TL T ? real id L ? id R , # R ? , id R R ? ? 42.给定文法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)文法。

35

《编译原理》复习题

表1 SLR分析表

状态 0 1 2 3 4 5 a S1 S1 S1 ACTION b S2 S2 S2 # r3 acc r1 r2 GOTO S 3 4 5

43.给出表达式-a*b+b*c+d/e的语法树和三元式序列。

答:语法树 三元式

+ + * * - a b b c d e / ①(-,a,-) ②(*,①,b) ③(*,b,c) ④(+,②,③) ⑤(/,d,e) ⑥(+,④,⑤)

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

45.现有文法G[S]

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

请给出句子(a,(a,a))的最左、最右推导,并指出最右推导中每一个句型的句柄。 答:最左推导:S=〉(T)=〉(T,S)=〉(S,S)=〉(a,S)=〉(a,(T))=〉(a,(T,S))=〉(a,(S,S))=〉(a,(a,S))=〉(a,(a,a))

最右推导: S=〉(T)=〉(T,S)=〉(T,(T))=〉(T,(T,S))=〉(T,(T,a))=〉(T,(S,a))=〉(T,(a,a))=〉(S,(a,a))=〉(a,(a,a))

句型的句柄是为加下划线的部分

36

《编译原理》复习题

46.将下图的DFA最小化。

1 a 3 a b 2 a b b a 4 a b b 0 答:初始划分:II={{0,1,2},{3,4}}(1分)

(1)考查{0,1,2},1和2接受a,b后都转向相同的状态,且接受b后转向终态,而0接受b后转向非终态2,所以0与1,2可分,IInew={{0},{1,2},{3,4}}(1分)

(2)考查{3,4},接受a,b后都转向相同的状态,所以3,4不可分。IInew={{0},{1,2},{3,4}}(1分)

将1,2合并用1代表,3,4合并用3代表,最终的最小化DFA如下:

a 0 b 1 b a b 3

47.设有如下文法:P→D

D→D;D|id:T|proc id;D; T→real|integer

给出一个语法制导定义,打印该程序一共声明了多少个id。 答: 文法 P→D D→D1;D2 D→id:T D→proc id;D1; T→real T→integer 语法制导定义 Print(D.num) D.num=D1.num+D2.num D.num=1 D.num=D1.num+1

48.识别文法G的活前缀的DFA如下图所示,补充完成状态I2和I5,然后根据该图构造SLR(1)分析表。

G:(0) P'→P (1) P→aPb (2) P→Q (3) Q→bQc (4) Q→bSc (5) S→Sa (6) S→a

37

《编译原理》复习题

P I1 :P'→P. I2 : I4 :P→aP.b I0 :P'→.P a P P→.aPb b P→.Q I7 :P→aPb. a Q→.bQc b Q→.bSc I8 :Q→bQc. Q b Q I c 5 : I3 :P→Q. I9 :Q→bQ.c Q b I10 :Q→bS.c S I6 : S→a. S→S.a a c I11 :Q→bSc. a I12 : S→Sa.

答:I2,I5分别如下图所示:

Follow(P)={b,$} 1分 Follow(Q)={ b,c,$} 1分 Follow(S)={c,a} 1分 SLR(1)分析表: 0 1 2 3 4 5 6 7 8 9 10 11 12 a S2 S2 S6 R6 S12 R5 b S5 S5 R2 S7 S5 R1 R3 R4 Action表 c R6 R3 S8 S11 R4 R5 $ Acc R2 R1 R3 R4 P 1 4 I2 :P→a.Pb P→.aPb P→.Q Q→.bQc Q→.bSc I5 :Q→b.Qc Q→b.Sc Q→.bQc Q→.bSc S→.Sa S→.a GOTO表 Q 3 3 9 S 10 49.给出表达式(a+b)*(c+d/e)的语法树和四元式序列。

38

《编译原理》复习题

答:语法树如下: 四元式序列:

* + + / a b c ①(+,a,b,T1) ②(/,d,e,T2) d e ③(+,c,T2,T3) ④(*,T1,T3,T4) ε B → ε 50.构造文法S→AaAb|BbBa A→ ,的预测分析表。

答:first(S)={a,b},First(AaAb)={a},First(BbBa )={b} Follow(A)={a,b} Follow(B)={a,b}

a b $ S S→AaAb S→BbBa A A→ε A→ε B B→ε B→ε

51.写出C语言标识符集(字母或下划线开头的由字母、数字、下划线构成的串)的正规式。 解答:用D表示数字0-9,用L表示字母a-z|A-Z,则C语言标识符的正规式为:

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

52.有一语法制导定义如下,其中+表示符号连接运算: 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,且采用自底向上的分析方法,则输出序列为(__________baba_________)。用分析树表示求解过程。

S Print baba B B.vers=baba B b B.vers=aba B a B.vers=ba B b B.vers=a a

53.假设第一个四元式的序号是100,写出布尔表达式ae的四元式序列。

39

《编译原理》复习题

100 (j<, a, b, 106) 101 (j, _, _ , 102) 102 (jnz, c, _ ,104) 103 (j,_ ,_ ,q) 104 (j>,d, e, 106) 105 (j,_ , _ , q ) T:106 …… F:q …….

54.设有如下文法: G[E]:E→EWT|T T→T/F|F

F→(E)|a|b|c W→+|-

证明符号串a/(b-c)是句子。

解答:有推导E?T?T/F?F/F?a/F?a/(E)?a/(EWT)? a/(TWT)? a/(FWT)? a/(bWT)? a/(b-T)? a/(b-c),即从文法开始符号E能够推导出a/(b-c),所以a/(b-c)是文法G[E]的句子。 55.对于下列文法 G[S]: S→Sb|bA A→aA|a

(1)构造一个与G等价的LL(1)文法G′。 (2)对于文法G′,构造相应的LL(1)分析表。 解: (1)(5分)G′:S→bAS′ S′→b S′|ε

A→aA′

A′→A|ε

(2)(1分)FIRST(S)={ b } FIRST(S′)={ b,ε} FIRST(A)={a}

FIRST(A′)={a,ε} FOLLOW(S)={#} FOLLOW(S′)={#} FOLLOW(A)={b,#}

FOLLOW(A′)=(b,#)

LL(1)分析表:

S S′ A A′

a A→aA′ A′→A b S→bAS′ S′→b S′ A′→ε # S′→ε A′→ε 40

《编译原理》复习题

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

G[S]:S→(A) A→ABB|B B→b

解:拓广文法:(1分) S′→S (0)

S→(A) (1) A→ABB (2)

A→B (3) B→b (4)

识别活前缀的DFA:(4分)

I:S′→.S 0 S→.(A) S I1:S′→S. ( ) I2:S→(.A) A→.ABB A→.B B→.b B I5: A→B. I4: B→b. A I3:S→(A.) A→A.BB B→.b b I6: S→(A). B I7:A→AB.B B→.b B I8:A→ABB. b

FIRST集和follow集:(1分)

First(S)={(,c} follow( S)={#} First(A)={b} follow(A)={b,)} First(B)={b} follow(B)={b,)}

SLR(1)分析表:(4分) 0 1 2 3 4 5 6 7 8 ( S2 ) S6 R4 R3 R2 ACTION b S4 S4 R4 R3 S4 R2 # Acc R1 S 1 GOTO A 3 B 5 7 8 57.有一语法制导定义如下: S→bAb print “1” A→(B print “2”

41

《编译原理》复习题

A→a print “3” B→aA) print “4” 若输入序列为b(a(a(aa)))b,且采用自下而上的分析方法,则输出序列为(__34242421____)。

58.写出赋值语句X= -(a+b)/(c-d)-(a+b*c)的逆波兰表示。

Xab+-cd-/abc*+-=

59.为文法

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

写一语法制导定义,它输出句子中括号嵌套的最大层次数。

解: 使用num属性描述括号的嵌套最大层次数

S?→S print(S.num) S→(L) S.num=L.num+1 S→a S.num=0

L→L(1),S L.num=if L(1).num>S.num then LL→S L.num= S.num

每个式子1分。 60.设有文法G[S]: S→aAcB|Bd A→AaB|c B→bScA|b

该文法句型aAcbBdcc的句柄是_______Bd_____________。

61.2.已知文法G[S]如下:构造该文法的LR(0)分析表。

G[S]:S→BB B→aB|b 解:拓广文法:(1分) (0)S?→S (1)S→BB (2)B→aB (3)B→b

识别活前缀的DFA 如下:

(1)

.num else S.num

42

《编译原理》复习题

I0: S??.S S?.BB B?.ab S I1: S??S. B I2: B I5: B?.b b S?B.B S?BB. b B?.ab a a B?.b b I3: b I4: a B?a.B B?b. B?.ab B?.b B I6: B?aB. LR(0)分析表如下:

状态 Action Goto a b # S B 0 S3 S4 1 2 1 acc 2 S3 S4 5 3 S3 S4 6 4 R3 R3 R3 5 R1 R1 R1 6 R2 R2 R2 43