1、编译原理复习题1一、单项选择题概述部分1构造编译程序应掌握 。D A. 源程序 B. 目标语言 C. 编译方法 D. 以上三项都是2编译程序绝大多数时间花在 上。DA. 出错处理 B. 词法分析 C. 目标代码生成 D. 表格管理3编译程序是对 。DA. 汇编程序的翻译 B. 高级语言程序的解释执行C. 机器语言的执行 D. 高级语言的翻译4. 将编译程序分成若干“遍” ,是为了 。BA. 提高程序的执行效率 B. 使程序的结构更为清晰C 利用有限的机器内存并提高机器的执行效率D. 利用有限的机器内存但降低了机器的执行效率词法分析部分1DFA M(见图 1-1)接受的字集为 。D A. 以 0
2、 开头的二进制数组成的集合 B. 以 0 结尾的二进制数组成的集合 C. 含奇数个 0 的二进制数组成的集合 D. 含偶数个 0 的二进制数组成的集合 2词法分析器的输出结果是 。CA. 单词的种别编码 B. 单词在符号表中的位置C. 单词的种别编码和自身值 D. 单词自身值3正规式 M1 和 M2 等价是指 。CA. M1 和 M2 的状态数相等 B. M1 和 M2 的有向边条数相等C. M1 和 M2 所识别的语言集相等 D. M1 和 M2 状态数和有向边条数相等4词法分析器的加工对象是 。 C A中间代码 B单词 C源程序 D元程序5同正规式(a|b)*等价的正规式为 。D A(a|
3、b)+ Ba*|b* C(ab)* D(a*|b*)+6. 两个 DFA 等价是指: 。 DA. 这两个 DFA 的状态数相同B. 这两个 DFA 的状态数和有向弧条数都相等C. 这两个 DFA 的有向弧条数相等D. 这两个 DFA 接受的语言相同7. 下列符号串不可以由符号集 Sa,b上的正闭包运算产生的是:( A )A. B. a C. aa D. ab8称有限自动机 A1 和 A2 等价是指_。DAA1 和 A2 都是定义在一个字母表上的有限自动机BA1 和 A2 状态数和有向边数相等图 1-1X Y0011编译原理复习题2CA1 和 A2 状态数或有向边数相等DA1 和 A2 所能识别
4、的字符串集合相等9同正规式(a|b)+等价的正规式是 _。BA (a|b)* B (a|b) (a|b)* C (ab )*(ab) D (a|b)|(a|b) *语法分析1在规范归约中,用 来刻画可归约串。 BA. 直接短语 B. 句柄 C. 最左素短语 D. 素短语2若 B 为非终结符,则 AB 为 项目。DA. 归约 B. 移进 C. 接受 D. 待约3如果文法 G 是无二义的,则它的任何句子 。 AA. 最左推导和最右推导对应的语法树必定相同B. 最左推导和最右推导对应的语法树可能不同C. 最左推导和最右推导必定相同D. 可能存在两个不同的最左推导,但它们对应的语法树相同4下列动作中,
5、不是自下而上分析动作的是: 。BA. 移进 B. 展开C. 接受 D. 报错6若 a 为终结符,则 Aa 为 项目。BA. 归约 B. 移进 C. 接受 D. 待约7语法分析时所依据的是 。AA. 语法规则 B. 词法规则 C. 语义规则 D. 等价变换规则8文法 G:S xSx|y 所识别的语言是 。C A. xyx B. (xyx)* C. xnyxn (n0) D. x*yx*9下列动作中,不是自上而下分析动作的是: 。CA. 匹配 B. 展开C. 移进 D. 报错10若 A 为非终结符,则 A 为 项目。AA. 归约 B. 移进 C. 接受 D. 待约11文法 G:S xSx| xS|
6、y 所识别的语言是 。 A A. xmyxn(mn0) B. (xyx)* C. xnyxn(n0) D. x*yx*13由文法的开始符号出发经过若干步(包括 0 步)推导产生的文法符号序列称为_。BA语言 B句型 C句子 D句柄14在自上而下的语法分析中,应从 开始分析。CA句型 B句子 C文法开始符号 D句柄15一个文法 G,若_ ,则称它是 LL(1)文法。CAG 中不含左递归 BG 无二义性 CG 的 LL(1)分析表中不含多重定义的条目 DG 中产生式不含左公因子16项目 SS. 为 。D编译原理复习题3A.归约项目 B.移进项目C.待约项目 D.接受项目17. 语法分析器的输入是:
7、 。A A. Token 序列 B. 源程序C. 目标程序 D. 符号表18. 在 LR(0)的 Action 表中,如果某行中存在标记为“rj”的栏,则: 。 AA. 该行必定填满“rj” B. 该行未必填满“rj”C. 其他行可能也有“rj” D. goto 表中也可能有“rj”19. LR 分析过程中栈内存储的是 。 AA. 活前缀 B. 前缀C. 归约活前缀 D. 项目20.文法 G:S x xS | y 所识别的语言是 。 DAxxy n B(xxy) n Cxx nyx D(xx) ny21.若状态 k 含有项目“A .”,对任意非终结符 a,都用规则 “A ”归约的语法分析方法是
8、 。BALALR 分析法 BLR(0) 分析法 CLR(1) 分析法 DSLR(1)分析法22. 在 SLR(1)的 Action 表中,如果某行中存在标记为“rj”的栏,则: 。BA. 该行必定填满“rj” B. 该行未必填满“rj”C. 其他行可能也有“rj” D. goto 表中也可能有“rj”23. 一个 指明了在 LR 分析过程中的某个时刻所能看到产生式多大一部分。DA. 活前缀 B. 前缀C. 归约活前缀 D. 项目24.若状态 k 含有项目“A .”,且仅当输入符号 aFOLLOW(A)时,才用规则“A ”归约的语法分析方法是 。DALALR 分析法 BLR(0) 分析法 CLR
9、(1) 分析法 DSLR(1)分析法25设有文法 GT:TT*F|FFFP|PP(T)|a该文法句型 T*P(T*F)的句柄是下列符号串 。C A.(T*F) B. T*F C. P D. P(T*F)26LR 分析表中的转移表( goto)是以 作为列标题的。 BA终结符 B非终结符 C终结符或非终结符 D表示状态的整形数27编译程序的语法分析器必须输出的信息是 。 A A语法错误信息 B语法规则信息C语法分析过程 D语句序列28下列项目中为可移进项目的是 。C AEE . BL. CL.-L DFL*F.29LR 分析表中的动作表( action)是以 作为列标题的。 DA终结符 B非终结
10、符C终结符或非终结符 D终结符和结束符#30下列项目中为可归约项目的是 。BAE.E BL. CL-.L DFL*.F33LR 分析器的核心部分是一张分析表,该表由 _组成。D编译原理复习题4AACTION 表 BGOTO 表C预测分析表 DACTION 表和 GOTO 表 34在递归下降子程序方法中,若文法存在左递归,则会使分析过程产生_ _。DA回溯 B非法调用 C有限次调用 D无限循环 35最左简单子树的叶结点,自左至右排列组成句型的_。CA短语 B句型 C句柄 D间接短语36由文法的开始符号出发经过若干步(包括 0 步)推导产生的文法符号序列中,如果只含有终结符,则文法符号序列称为_。
11、CA语言 B句型 C句子 D句柄37LL(1)分析法中“1”的含义是在输入串中查看一个输入符号,其目的是_。CA确定最左推导 B确定句柄 C确定使用哪一个产生式进行展开 D确定是否推导语义分析1.表达式(ab)(e f)的逆波兰表示为 。 BAabef Ba bef Cab ef Dabef2中间代码生成时所依据的是 。CA词法规则 B语法规则 C语义规则 D等价变换规则3 -a-(b*c/(c-d)+(-b)*a)的逆波兰表示是 。(代表后缀式中的求负运算符) CA. abc*cd-ba*+/- B. abc*cd-ba*+/-C. abc*cd-/ba*+- D. abc*/cd-ba*+
12、-4有文法 G 及其语法制导翻译如下所示(语义规则中的*和+分别是常规意义下的算术运算符):EE (1) T E.val = E (1).val * T.valET E.val = T.valTT (1)# n T.val = T(1).val + n.val T n T.val = n.val则分析句子 1 2 3 # 4 其值为 。 CA. 10 B. 34 C. 14 D.545有文法 G 及其语法制导翻译如下所示(语义规则中的*和+分别是常规意义下的算术运算符):EE (1) T E.val = E (1).val * T.valET E.val = T.valTT (1)# n T.
13、val = T(1).val + n.val T n T.val = n.val则分析句子 2 3 # 4 其值为 。 CA. 10 B. 21 C. 14 D. 246间接三元式表示法的优点为 。 AA. 采用间接码表,便于优化处理 B. 节省存储空间,不便于表的修改C. 便于优化处理,节省存储空间 D. 节省存储空间,不便于优化处理7文法 GS及其语法制导翻译定义如下:产生式 语义动作S S print(S.num)S (L) S.num = L.num +1编译原理复习题5S a S.num = 0L L(1), S L.num = L(1).num + S.numL S L.num =
14、 S.num若输入为(a,(a),且采用自底向上的分析方法,则输出为 。CA0 B1 C2 D48四元式之间的联系是通过 _实现的。BA指示器 B临时变量 C符号表 D程序变量9表达式(ab)(c d)的逆波兰表示为 。BAabcd Ba bcdCab cd Dabcd10表达式 a+b+c+d 的逆波兰表示为 。BAa+bc+d+ Bab+c+d+Cab+cd+ Dabc+d+11.有文法 G 及其语法制导翻译如下所示(语义规则中的*和+分别是常规意义下的算术运算符):EE(1) T E.val = E(1).val * T.valET E.val = T.valTT(1)# n T.val
15、 = T(1).val + n.val T n T.val = n.val则分析句子 3 3 # 4 其值为 。B A. 10 B. 21 C. 14 D. 2412表达式 a+b+c 的逆波兰表示为 。BAa+bc+ Bab+c+C+abc+ Dabc+13. 文法 GS及其语法制导翻译定义如下:产生式 语义动作S S print(S.num)S (L) S.num = L.num +1S a S.num = 0L L(1), S L.num = L(1).num + S.numL S L.num = S.num若输入为(a, a), 且采用自底向上的分析方法,则输出为 。BA0 B1C2
16、D414有一语法制导翻译定义如下:SbAb print “1”A(B print “2”Aa print “3”BaA) print “4”若输入序列为 b(a(a (aa) ) )b,且采用自底向上的分析方法,则输出序列为 。BA32224441 B34242421C12424243 D3444221215赋值语句 X:=-(a+b)/(c-d)-(a+b*c)的逆波兰表示是 。CA. Xab+cd-/-bc*a+-:=B. Xab+/cd-bc*a+-:=C. Xab+-cd-/ a bc* +-:=编译原理复习题6D. Xab+cd-/abc* +-:=16有一语法制导翻译定义如下,其中
17、+表示符号连接运算:SB print B.versBa B.vers=aBb B.vers=bBBa B.vers=a+B.versBBb B.vers=b+B.vers若输入序列为 abab,且采用自底向上的分析方法,则输出序列为 。DAaabb Babab Cbbaa Dbaba17编译程序不能检查、处理的错误是程序中的_。BA静态语义检查 B动态语义检查 C语法错误 D词法错误(优化、存储、错误管理)1.在编译过程中,如果遇到错误应该 。CA. 把错误理解成局部的错误 B. 对错误在局部范围内进行纠正,继续向下分析C. 当发现错误时,跳过错误所在的语法单位继续分析下去D. 当发现错误时立
18、即停止编译,待用户改正错误后再继续编译二、填空题概述部分:1编译程序的开发常常采用自编译、 交叉编译 、 自展 和移植等技术实现。2解释程序和编译程序的区别在于 是否生成目标程序 。3如果编译程序生成的目标程序是汇编语言程序,则源程序的执行分为 3 个阶段: 编译阶段 、 汇编阶段 和 运行阶段 。4编译程序工作过程中,第一阶段输入是 源程序 ,最后阶段的输出为 目标程序 。5编译过程通常可分为 5 个阶段 词法分析阶段 、 语法分析阶段 、 语义分析和中间代码生成阶段 、优化阶段和目标代码生成阶段。6如果编译阶段生成的目标程序是某特定计算机系统的机器代码程序,则源程序的执行分为两大阶段: 编
19、译阶段 和 运行阶段 。7对编译程序而言,输入数据是 源程序 ,输出结果是 目标程序 。8贯穿于编译程始终的工作有 符号表处理 和出错处理。词法分析部分:1词法分析的工作是将源程序中的 字符串 变换成 单词符号流 的过程,所遵循的是语言的 构词规则 。2若两个正规式所表示的 正规集 相同,则认为二者是等价的。3若两个正规式所表示的正规集相同,则认为二者是 等价 的。4正规式 R1 和 R2 等价是指_表示相同的正规集 。5词法分析器的输入是源程序字符串,输出结构是 二元式(单词种别, 单词自身的值) 。词法分析所遵循的是语言的 构词 规则。6确定的有限自动机是一个五元组,包含的五个元分别是:状
20、态集合、 字母表、初态、终态集、状态转换函数集合 。7有限自动机是更一般化的状态转换图,它分为 确定的有限自动机 DFA 和 非确定的有限自动机编译原理复习题7NFA 两种。8NFA 和 DFA 的区别主要有两点:其一是 NFA 可以有若干个初始状态,而 DFA 仅有一个初始状态 ;其二是 NFA 的状态转换函数 f 不是单值函数,而是一个多值函数 。语法分析部分:(基本概念、LL(1) 、LR(0) 、SLR(1) 、递归下降子程序)1 语法分析的方法通常分为两类: 自上而下分析方法 和 自下而上分析方法 。2文法中的终结符集和非终结符集的交集是 空集 。3一个句型的最左直接短语称为该句型的
21、_句柄_。4规范归约是 最右推导 的逆过程。5自下而上语法分析中分析器的动作有_移进 、_归约 、_接受_ 、_报错 _。6自上而下语法分析中分析器的动作有_匹配终结符_、_展开非终结符_、_分析成功、报错_。7常用的自上而下语法分析方法有递归下降子程序方法和预测分析表方法(LL(1)方法) 。8常用的自下而上语法分析方法有算符优先分析法和 LR 分析法。9一个 LL(1)分析器由 一张 LL(1)分析表(预测分析表) 、 一个先进后出分析栈 和一个 控制程序(表驱动程序)组成。10一个 LR 分析器由 分析栈 、 分析表 和总控程序三个部分组成。11LR(0)分析法的名字中, “L”表示 自
22、左至右分析输入串 , “R”表示 采用最右推导的逆过程即最左归约 。 “0”表示 向右查看 0 个字符 。12LL(1)分析法中,第一个 L 的含义是 从左到右扫描输入串 ;第二个 L 的含义是 分析过程中采用最左推导 ;“1”的含义是 只需向右查看一个符号就可以决定如何推导 。13LR(1)文法的含义是:L 表明_自左至右扫描输入串_,R 表明_采用最右推导的逆过程(最左归约)方法进行分析_。14一个上下文无关文法是 LL(1)文法的充分必要条件是:对每一个非终结符 A 的任何两个不同产生式A| ,有下面的条件成立:(1) FIRST()FIRST() = ;(2)假若 ,则有 FIRST(
23、) FOLLOW(A) = 。15对于 LL(1)文法中的任何产生式 A|,则需要满足_First(_)First()= 、_若_=*,则_ First(_) _Follow(A)=_ _。16LR 分析器的核心部分是一张分析表,该表包括 动作( ACTION)表 和 状态转换(GOTO)表 等两个子表。17关于非终结符 A 的直接左递归产生式: AA|,其中 、 是任意的符号串且 不以 A 开头,则可以将 A 的产生式改写为右递归的形式为: AA , AA| 。18在消除回溯,提取公共左因子时,关于 A 的产生式 A 1 | 2 | | i | i+1 | | j,可以改写为: A A |
24、i+1 | | j , A 1 | |i 。19设 GS 是一文法,如果符号串 x 是从识别符号推导出来的,即有 x,则称 x 是文法 GS的_*S句型_,若 x 仅由终结符号组成,即 ,则称 x 为文法 GS的_句子 。*,TVS20已知文法 GS:SeT|RT TDR| RdR| Da|bd求 FIRST(S)=e,d,a,b,_ ;FOLLOW(D)=_ d,# 。语义处理部分:1文法符号的属性有两种,一种称为 继承属性 ,另一种称为 综合属性 。2编译过程中,常见的中间语言形式有 逆波兰表示法 、 抽象语法树 、 三元式 、 四元式 。3语法制导翻译的方法就是为每个产生式配上一个 翻译
25、子程序(语义动作或语义子程序) ,并在语编译原理复习题8法分析的同时执行它们。4编译过程中,常见的中间语言形式有 逆波兰表示法 、 抽象语法树 、 三元式 、 四元式 。6文法符号的属性有两种,一种称为 继承属性 ,另一种称为 综合属性 。7四元式之间的联系是通过 临时变量 实现的。8在属性文法中,终结符只有_综合 属性。10语法制导翻译的方法就是为每个产生式配上一个 翻译子程序(语义动作或语义子程序) ,并在语法分析的同时执行它们。11目前较常见的语言语义的描述形式是_属性文法_,并使用_语法制导翻译 方法完成对语法成分的翻译。(优化、存储、错误管理)1.代码优化的含义是:对代码进行 等价变
26、换 ,使得变换后的代码具有更高的 时间效率 和 空间效率。2.按照优化对象所涉及的程序范围,优化分为 局部优化 、 循环优化 和 全局优化 。3.基本块,是指程序中 顺序执行的语句序列 ,其中只有一个 入口 和一个 出口 。4.从编译角度看,分配目标程序数据空间的基本策略有: 静态分配策略 、 栈式动态分配策略 和堆式动态分配策略 。三、判断题1设 r 和 s 分别为正规式,则有 L(r|s) = L(r) | L(s).。( )2一个文法的所有句型的集合形成该文法所能接受的语言。( )3语法分析之所以采用上下文无关文法是因为它的描述能力最强。( )4由于 LR(0)分析表构造简单,所以它的描
27、述能力强,适用面宽;LR(1)分析表因构造复杂而描述能力弱,适用面窄。( )5逆波兰表示法表示表达式时无需使用括号。( )6自动机 M 和 M的状态个数不同,则二者必不等价。( )7LL(1)文法一定不含左递归和二义性。( )8所有 LR 分析器的总控程序都是一样的,只是分析表各有不同。( )9无论是三元式表示还是间接三元式表示的中间代码,其三元式在三元式表中的位置一旦确定就很难改变。( )10三地址语句类似于汇编语言代码,可以看成中间代码的一种抽象形式。( )11最左推导也被称为规范推导。 ( )12运算对象排列的先后顺序在后缀式和中缀式中不同。 ( )13出现在移进-归约分析器栈中的内容被
28、称为文法 G 的活前缀。 ( )14LR 方法可以分析含有左递归的文法。 ( )15三元式的编号具有双重含义,既代表此三元式,又代表三元式存放的结果。 ( )16语义规则中的属性有两种:综合属性与继承属性。 ( )17移进-归约分析器的格局中栈的内容一般是文法符号与状态。 ( )18由于递归下降子程序方法较 LL(1)方法简单,因此它要求文法不必是 LL(1)文法。 ( )19四元式的编号具有双重含义,既代表此四元式,又代表四元式存放的结果。 ( )20用高级语言编写的源程序必须经过编译,产生目标程序后才能运行。 ( )21源程序到目标程序的变换是等价变换,即两者结构不同,但语义是一致的。 (
29、 )22对于任何一个正规式 e,都存在一个 DFA A,使得 L(e)=L (A ) 。 ( )23最小化的 DFA,它的状态数最小。 ( )24NFA 的确定化算法具有消除 边的功能。 ( )25每个非终结符产生的终结符号串都是该语言的子集。 ( )26一个语言的文法是不唯一的。 ( )编译原理复习题927语法错误校正的目的是为了把错误改正过来。 ( )28源程序和目标程序是等价关系。 ( )29编译程序中错误处理的任务是对检查出的错误进行修改。 ( )30使用有限自动机可以实现单词的识别。 ( )31一个非确定的有限自动机 NFA 可以通过多条路径识别同一个符号串。 ( )32最小化的 D
30、FA 所识别接受的正规集最小。 ( )33一个语言(如 C 语言)的句子是有穷的。 ( )34LL(1)方法又称为预测分析方法。 ( )35一个 LL(1)文法是无二义和无回溯方法。 ( )36语法分析器可以检查出程序中的所有错误。 ( )37LR 分析法是自上而下的语法分析方法。 ( )三、多项选择题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*)*
31、3. 自上而下的分析方法有:(AD )A. 递归下降分析法 B. LR(0)分析法C. LALR(1)分析法 D. LL(1)分析法E. SLR( 1)分析法4. 文法 G:GS:S CD AbbACaCA BaaBCbCB BbbBADaD CBDbD DAabD是(A ) 。A. 0 型文法 B. 1 型文法C. 2 型文法 D. 3 型文法 E. 上下文有关文法5. 对 LR 分析表的构造,有可能存在的动作冲突有:( AD )A. 移进/归约冲突 B. 移进/ 移进冲突C. 归约冲突 D. 归约/归约冲突E. 移进冲突6. 一个编译器可能有的阶段为(ABCDE )A. 词法分析 B. 语
32、法分析C. 语义分析 D. 中间代码生成E. 目标代码生成7 令 a,b,则 上的所有以 b 开头,后跟若干个(可为 0 个)ab 的符号串的全体可用下面的正规式表示。 (AB )A.b (ab)* B. (ba)*b C. b(a|b)+ D. (ba)+b 编译原理复习题10E. b (a|b)*8. 自下而上的分析方法有:(BCE )A. 递归下降分析法 B. LR(0)分析法C. LALR(1)分析法 D. LL(1)分析法E. SLR( 1)分析法9. 一般来说,编译器可分为前端和后端,下列编译阶段可被划分为编译的前端的有:(ABCDE )A. 词法分析 B. 语法分析C. 语义分析
33、 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. (aba) (aba)E. ab ab12正规式服从的代数规律有:(ABDE )A. “或”运算服从交换律 B. “或”运算服从结合律C. “连接 ”运算服从交换律 D. “连接”运算服从结合律E. “连接 ”运算可对“或”运算进行分配13 令 a,b,则 上的所有以 b 开头,后跟若干个(
34、可为 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 表中的每一项 ActionS,a所表示的动作可能为:(ABCD )A. 移进 B. 接受 C. 归约D. 出错 E. 待约五简答题1构造正规表达式(a|b)*|aa)*b 的 NFA。解: XY13a24bba
Copyright © 2018-2021 Wenke99.com All rights reserved
工信部备案号:浙ICP备20026746号-2
公安局备案号:浙公网安备33038302330469号
本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。