编译原理期末复习题(含答案)

上传人:新** 文档编号:547648832 上传时间:2023-09-05 格式:DOC 页数:39 大小:61.50KB
返回 下载 相关 举报
编译原理期末复习题(含答案)_第1页
第1页 / 共39页
编译原理期末复习题(含答案)_第2页
第2页 / 共39页
编译原理期末复习题(含答案)_第3页
第3页 / 共39页
编译原理期末复习题(含答案)_第4页
第4页 / 共39页
编译原理期末复习题(含答案)_第5页
第5页 / 共39页
点击查看更多>>
资源描述

《编译原理期末复习题(含答案)》由会员分享,可在线阅读,更多相关《编译原理期末复习题(含答案)(39页珍藏版)》请在金锄头文库上搜索。

1、编译原理期末复习题(含答案)第八节 习题一、单项选择题1、将编译程序分成若干个“遍”是为了 。 a提高程序的执行效率 b使程序的结构更加清晰c利用有限的机器内存并提高机器的执行效率 d利用有限的机器内存但降低了机器的执行效率 2、构造编译程序应掌握 。 a源程序 b目标语言 c编译方法 d以上三项都是 3、变量应当 。 a持有左值 b持有右值c既持有左值又持有右值 d既不持有左值也不持有右值 4、编译程序绝大多数时间花在 上。 a出错处理 b词法分析 c目标代码生成 d管理表格 5、 不可能是目标代码。 a汇编指令代码 b可重定位指令代码 c绝对指令代码 d中间代码 6、使用 可以定义一个程序

2、的意义。 a语义规则 b词法规则 c产生规则 d词法规则 7、词法分析器的输入是 。 a单词符号串 b源程序 c语法单位 d目标程序 8、中间代码生成时所遵循的是- 。 a语法规则 b词法规则 c语义规则 d等价变换规则 9、编译程序是对 。 a汇编程序的翻译 b高级语言程序的解释执行 c机器语言的执行 d高级语言的翻译 10、语法分析应遵循 。 a语义规则 b语法规则 c构词规则 d等价变换规则 解答1、将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选b。 2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选d。 3、对编译而言,变量既持有左值又持有右值,故选c

3、。 4、编译程序打交道最多的就是各种表格,因此选d。5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,因此不是目标代码的只能选d。6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。因此选a。 7、b 8、c 9、d 10、c 二、多项选择题1、编译程序各阶段的工作都涉及到 。 a语法分析 b表格管理 c出错处理 d语义分析 e词法分析2、编译程序工作时,通常有 阶段。 a词法分析 b语法分析 c中间代码生成 d语义检查 e目标代码生成 解答1b、c 2. a、b、c、e 三、填空题1、解释程序和编译程序的区

4、别在于 。2、编译过程通常可分为5个阶段,分别是 、语法分析 、代码优化和目标代码生成。 3、编译程序工作过程中,第一段输入是 ,最后阶段的输出为 程序。4、编译程序是指将 程序翻译成 程序的程序。 解答是否生成目标程序 2、词法分析 中间代码生成 3、源程序 目标代码生成 4、源程序 目标语言一、单项选择题1、文法G:SxSx|y所识别的语言是 。nn a. xyx b. (xyx)* c. xyx(n0) d. x*yx* 2、文法G描述的语言L(G)是指 。+ , V* *, V* a. L(G)=|Sb. L(G)=|STT*+ c. L(G)=|S,(VTVN*) d. L(G)=|

5、S, (VTVN*)3、有限状态自动机能识别 。 a. 上下文无关文法 b. 上下文有关文法c.正规文法 d. 短语文法4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立 。 a. 若f(a)g(b),则ab b.若f(a)c. ab都不一定成立 d. ab一定成立5、如果文法G是无二义的,则它的任何句子 。 a. 最左推导和最右推导对应的语法树必定相同b. 最左推导和最右推导对应的语法树可能不同 c. 最左推导和最右推导必定相同d. 可能存在两个不同的最左推导,但它们对应的语法树相同6、文法的开始符经0步或多步推导产生的文法符号序列是 。 a. 短语 b.句柄 c. 句型 d. 句

6、子 7、文法G:EE+T|TTT*P|P P(E)|I则句型P+T+i的句柄和最左素短语为 。 +T和i b. P和P+T c. i和P+T+i 和T 8、设文法为:SSA|AAa|b则对句子aba,下面 是规范推导。 a. SSASAAAAAaAAabAabab. SSASAAAAAAAaAbaaba c. SSASAASAaSbaAbaaba d. SSASaSAaSbaAbaaba 9、文法G:Sb|(T) TT,S|S则FIRSTVT(T) 。 a. b,( b. b,)10、产生正规语言的文法为 。c.b,(,, d.b,),,a. 0型 b. 1型 c. 2型 d. 3型 11、采

7、用自上而下分析,必须 。 a. 消除左递归 b. 消除右递归 c. 消除回溯 d. 提取公共左因子 12、在规范归约中,用 来刻画可归约串。 a. 直接短语 b. 句柄 c. 最左素短语 d. 素短语 13、有文法G:EE*T|TTT+i|i句子1+2*8+6按该文法G归约,其值为 。a. 23 B. 42 c. 30 d. 17 14、规范归约指 。 a. 最左推导的逆过程 b. 最右推导的逆过程 c. 规范推导 d. 最左归约的逆过程 解答1、选c。2、选a。 3、选c。 4、虽然a与b没有优先关系,但构造优先函数后,a与b就一定存在优先关系了。所以,f(a)g)(b)或f(a)5、如果文

8、法G无二义性,则最左推导是先生长右边的枝叶:对于d,如果有两个不同的是了左推导,则必然有二义性。故选a。6、选c。7、图2-8-1的语法树和优先关系可以看出应选b。EE + FE + T PT iP#+# 图2-8-1 句型P+T+I的语法及优先关系8、规范推导是最左推导,故选d。9、TT,和T( 得FIRSTVT(T)=(,,);TS得FIRSTVT(S)FIRSTVT(T),而FIRSTVT(S)=b,(;即 FIRSTVT(T)=b,(,,; 因此选c。 10、d 11、c 12、b 13、b 14、b 二、多项选择题1、下面哪些说法是错误的 。 a. 有向图是一个状态转换图 b. 状态

9、转换图是一个有向图c.有向图是一个DFA 可以用状态转换图表示 2、对无二义性文法来说,一棵语法树往往代表了 。a. 多种推导过程 b. 多种最左推导过程 c.一种最左推导过程 d.仅一种推导过程 e.一种最左推导过程3、如果文法G存在一个句子,满足下列条件 之一时,则称该文法是二义文法。 a. 该句子的最左推导与最右推导相同b. 该句子有两个不同的最左推导 c. 该句子有两棵不同的最右推导 d. 该句子有两棵不同的语法树e.该句子的语法树只有一个 4、有一文法G:SAB AaAb| BcBd| 它不产生下面 集合。a. anbmcndm|n,m0 b. anbncmdm|n,m0 c. an

10、bmcmdn|n,m0 d. anbncmdm|n,m0 e. anbncndn|n05、自下而上的语法分析中,应从 开始分析。 a. 句型 b. 句子 c. 以单词为单位的程序 d. 文法的开始符 e. 句柄6、对正规文法描述的语言,以下 有能力描述它。型文法 型文法 c.上下文无关文法 d.右线性文法 e.左线性文法解答 1、e、a、c 2、a、c、e 3、b、c、d 4、a、c 5、b、c 6、a、b、c、d、e 三、填空题1、文法中的终结符和非终结符的交集是 。词法分析器交给语法分析器的文法符号一定是 ,它一定只出现在产生式的 部。2、最左推导是指每次都对句型中的 非终结符进行扩展。3

11、、在语法分析中,最常见的两种方法一定是 分析法,另一是 分析法。 4、采用 语法分析时,必须消除文法的左递归。 5、 树代表推导过程, 树代表归约过程。6、自下而上分析法采用 、归约、错误处理、 等四种操作。7、Chomsky把文法分为 种类型,编译器构造中采用 和 文法,它们分别产生 和 语言,并分别用 和 自动机识别所产生的语言。 解答 1、空集 终结符 右 2、最左3、自上而上 自下而上 4、自上而上5、语法 分析 6、移进 接受7、4 2 型 3型 上下文无关语言 正规语言 下推自动机 有限 四、判断题1、文法 SaS|bR|描述的语言是(a|bc)* ( ) RcS2、在自下而上的语

12、法分析中,语法树与分析树一定相同。 3、二义文法不是上下文无关文法。 4、语法分析时必须先消除文法中的左递归。 5、规范归约和规范推导是互逆的两个过程。 6、一个文法所有句型的集合形成该文法所能接受的语言。 解答 1、对 2、错 3、错 4、错 5、错 6、错 五、简答题1、句柄 2、素短语 3、语法树 4、归约 5、推导 解答1、句柄:一个句型的最左直接短语称为该句型的句柄。2、素短语:至少含有一个终结符的素短语,并且除它自身之外不再含任何更小的素短语。 3、语法树:满足下面4个条件的树称之为文法GS的一棵语法树。 每一终结均有一标记,此标记为VNVT中的一个符号;树的根结点以文法GS的开始

13、符S标记;若一结点至少有一个直接后继,则此结点上的标记为VN中的一个符号; 若一个以A为标记的结点有K个直接后继,且按从左至右的顺序,这些结点的标记分别为X1,X2,XK,则AX1,X2,XK,必然是G的一个产生式。 4、归约:我们称直接归约出A,仅当A 是一个产生式,且、(VNVT)*。归约过程就是从输入串开始,反复用产生式右部的符号替换成产生式左部符号,直至文法开始符。5、推导:我们称A直接推出,即A,仅当A 是一个产生式,且、(VNVT)*。如果12n,则我们称这个序列是从1至2的一个推导。若存在一个从1n的推导,则称1可推导出n。推导是归约的逆过程。六、问答题1、给出上下文无关文法的定

14、义。 解答一个上下文无关文法G是一个四元式,其中: VT是一个非空有限集,它的每个元素称为终结符号;VN是一个非空有限集,它的每个元素称为非终结符号,VTVN=; S是一个非终结符号,称为开始符号; P是一个产生式集合,每个产生式的形式是P,其中,PVN, (VTVN)*。开始符号S至少必须在某个产生式的左部出现一次。 2、文法GS:SaSPQ|abQ QPPQ bPbb bQbc cQcc它是Chomsky哪一型文法? 它生成的语言是什么? 解答 于产生式左部存在终结符号,且所有产生式左部符号的长度均小于等于产生式右部的符号长度,所以文法GS是Chomsky1型文法,即上下文有关文法。按产生式出现的顺序规定优先级高到低,我们可以得到: SabQabcSaSPQaabQPQaabPQQaabbQQaabbcQaabbccSaSPQaaSPQPQaaabQPQPQaaabPQQPQaaabPQPQQaaaPPQQQ aaabbPqqqaaabbQQQaaabbbcQQaaabbbccQaaabbbccc 于是得到文法GS生成的语言L=anbncn|n1 3、按指定类型,给出语言的文法。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号