河南科技大学期末考试编译原理试卷及答案
编译原理期末考试试题及答案

编译原理期末考试试题及答案一、选择题(每题2分,共20分)1. 编译器的前端主要负责以下哪项工作?A. 代码优化B. 目标代码生成C. 词法分析和语法分析D. 运行时支持2. 词法分析器的主要任务是什么?A. 识别语法结构B. 识别词法单元C. 构建语法树D. 代码优化3. 语法分析中,使用哪种方法可以避免回溯?A. 递归下降分析B. LR分析C. LL分析D. 自顶向下分析4. 下列哪个选项不是中间代码的形式?A. 三地址代码B. 四元组C. 抽象语法树D. 汇编语言5. 代码优化的目标不包括以下哪项?A. 提高代码执行速度B. 减少程序占用的内存C. 增加程序的可读性D. 减少程序的执行时间二、简答题(每题10分,共30分)1. 简述编译器的主要组成部分及其功能。
2. 解释什么是语法制导翻译,并举例说明其在编译过程中的应用。
3. 描述静态作用域规则和动态作用域规则的区别。
三、计算题(每题15分,共30分)1. 给定一个简单的算术表达式 `3 + (4 * 5) - 2`,请使用逆波兰表示法表示,并说明其转换过程。
2. 假设有一个简单的文法如下:```S -> A BA -> a A | εB -> b B | ε```请写出使用该文法生成字符串 "ab" 的所有派生树。
四、论述题(每题20分,共20分)1. 论述编译器中代码优化的重要性,并举例说明常见的优化技术。
参考答案一、选择题1. C2. B3. B4. D5. C二、简答题1. 编译器的主要组成部分包括前端、中端和后端。
前端负责词法分析和语法分析,中端进行语义分析和中间代码生成,后端则负责代码优化和目标代码生成。
2. 语法制导翻译是一种基于文法规则的翻译技术,它将源程序的语法结构映射到相应的语义操作上。
例如,在编译过程中,语法制导翻译可以用于将源代码中的条件语句转换为中间代码中的跳转指令。
3. 静态作用域规则是指变量的作用域在编译时确定,而动态作用域规则是指变量的作用域在运行时确定。
完整word版,编译原理期末试题(8套含答案)详解,推荐文档

《编译原理》期末试题(一)一、是非题(请在括号内,正确的划√,错误的划×)(每个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)卷一、填空题(每小题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::=ABCC::=0|2|4|6|8 C::=0|2|4|6|8B::=BA|B0|ε B::=BA|B0|0A::=1|2|3|…|9 A::=1|2|3|…|9C. Z::=ABC|2|4|6|8D. Z::=ABC|2|4|6|8C::=0|2|4|6|8 C::=0|2|4|6|8B::=BA|B0|0 B::=BA|B0|εA::=1|2|3|…|9 A::=1|2|3|…|93、简单优先分析法从左到右扫描输入串,当栈顶出现()时进归约。
A.素短语B.直接短语C.句柄D.最左素短语4、同心集合并有可能产生新的()冲突。
《编译原理》期末考试题库含答案.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.词法分析器用于识别_____ oA.()字符串B.()语句C.()单词D.()标识符3 •语法分析器则可以发现源程序中的______ oA.()语义错误B.()语法和语义错误C.()错误并校正D.()语法错误4.下面关于解释程序的描述正确的是。
(1) 解释程序的特点是处理程序时不产生目标代码(2) 解释程序适用于COBOL 和FORTRAN 语言(3) 解释程序是为打开编译程序技术的僵局而开发的A. ( ) (1) (2)B. () (1)C. () (1)⑵(3)D.()⑵⑶5. _________________________________________ 解释程序处理语言时,大多数采用的是 ___________________________________ 方法。
大学计算机编译原理期末复习试题(含有答案).docx

大学计算机编译原理期末复习试题(含有答案)习题一、单项选择题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、使用可以定义一个程序的意义。
a.语义规则b.词法规则c.产生规则d.词法规则7、词法分析器的输入是。
a.单词符号串b.源程序c.语法单位d.目标程序8、中间代码生成时所遵循的是。
a.语法规则b.词法规则c.语义规则d.等价变换规则9、编译程序是对。
a.汇编程序的翻译b.高级语言程序的解释执行c.机器语言的执行d.高级语言的翻译10、语法分析应遵循。
а.语义规则b.语法规则c.构词规则d.等价变换规则解答1、将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选b。
2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选d。
3、对编译而言,变量既持有左值又持有右值,故选c。
4、编译程序打交道最多的就是各种表格,因此选d。
5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,因此不是目标代码的只能选d。
б、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。
因此选a。
7、b 8、c 9、d 10、c二、多项选择题1、编译程序各阶段的工作都涉及到。
a.语法分析b.表格管理c.出错处理d.语义分析e.词法分析2、编译程序工作时,通常有阶段。
a.词法分析b.语法分析c.中间代码生成d.语义检查e.目标代码生成解答1. b、c2. a、b、c、e三、填空题1、解释程序和编译程序的区别在于。
编译原理期末复习题及答案

编译原理期末复习题及答案# 一、选择题1. 编译程序的前端主要完成以下哪项工作?A. 代码优化B. 目标代码生成C. 词法分析D. 运行时支持答案:C2. 语法分析中,用于表示语法规则的是:A. 正则表达式B. 语法树C. 产生式D. 语法图答案:C3. 语义分析的主要任务是:A. 识别词法单位B. 构建语法树C. 确定语法单位的意义D. 生成中间代码答案:C4. 下列哪一项不是中间代码的形式?A. 三地址代码B. 四元组C. 抽象语法树D. 汇编语言答案:D5. 代码优化的目的是:A. 增加程序的可读性B. 减少程序的运行时间C. 提高程序的执行安全性D. 增强程序的可移植性答案:B# 二、简答题1. 简述词法分析的主要任务和实现方法。
答案:词法分析的主要任务是将源程序文本分解成一系列的词法单元,即标记。
实现方法通常包括模式匹配和状态转换,使用有限自动机(如正则表达式引擎)来识别词法单元。
2. 描述语法分析的过程,并解释递归下降分析法。
答案:语法分析是将词法分析得到的标记序列转换成一个语法树的过程。
递归下降分析法是一种自顶向下的语法分析方法,它通过递归调用分析函数,根据当前的输入符号和语法规则来决定下一步的分析动作。
3. 解释代码优化中的“死码消除”是什么,并给出一个例子。
答案:死码消除是一种代码优化技术,用于删除程序中不再使用的代码,这些代码对程序的输出没有影响。
例如,如果一个变量的值在赋值后不再被使用,那么这个赋值语句就是死码,可以被消除。
# 三、计算题1. 给定一个简单的算术表达式 `a + b * c`,请使用递归下降分析法生成其语法树。
答案:首先识别 `a` 和 `b` 为因子,然后识别 `*` 为乘法操作符,接着识别 `c` 为因子。
根据运算符优先级,先计算 `b * c`,再与 `a` 相加。
语法树结构如下:```+/ \a */ \b c```2. 给定一个简单的三地址代码序列 `[1] = a + [2]`,`[2] = b * c`,请转换为四元组形式。
编译原理期末试题及答案

编译原理期末试题及答案一、选择题(每题2分,共20分)1. 编译器的主要功能是将()代码转换成()代码。
A. 高级语言,低级语言B. 高级语言,机器语言C. 汇编语言,机器语言D. 机器语言,汇编语言答案:B2. 编译过程中,词法分析的输出是()。
A. 语法树B. 语法分析表C. 词法单元D. 抽象语法树答案:C3. 在编译原理中,语法分析通常采用()方法。
A. 递归下降分析B. 动态规划C. 贪心算法D. 回溯算法答案:A4. 语义分析的主要任务是()。
A. 检查语法错误B. 生成中间代码C. 检查语义错误D. 优化代码答案:C5. 编译器的优化通常发生在()阶段。
A. 词法分析B. 语法分析C. 语义分析D. 代码生成答案:D6. 编译器的前端主要负责()。
A. 代码生成B. 代码优化C. 语法分析D. 目标代码生成答案:C7. 编译器的后端主要负责()。
A. 代码生成B. 代码优化C. 语法分析D. 词法分析答案:A8. 编译原理中,LL(1)分析方法的特点是()。
A. 左到右,最右推导B. 左到右,最左推导C. 右到左,最右推导D. 右到左,最左推导答案:B9. 编译原理中,LR(1)分析方法的特点是()。
A. 左到右,最右推导B. 左到右,最左推导C. 右到左,最右推导D. 右到左,最左推导答案:B10. 编译原理中,语法制导翻译的主要思想是()。
A. 根据语法树的结构进行翻译B. 根据词法单元进行翻译C. 根据语法分析表进行翻译D. 根据语义分析表进行翻译答案:A二、填空题(每题2分,共20分)1. 编译器中,用于表示语法规则的产生式通常由非终结符、产生符号和()组成。
答案:产生式右侧2. 在编译原理中,一个文法是()的,如果它的任何两个产生式都不会导致相同的句柄。
答案:无二义性3. 编译器的词法分析阶段通常使用()算法来识别和分类词法单元。
答案:有限自动机4. 语法分析阶段,如果一个文法是左递归的,编译器需要使用()技术来消除左递归。
编译原理期末测试练习题及答案

一、单选题1、编译程序是一种( )。
A.汇编程序B.目标程序C.翻译程序D.解释程序正确答案:C2、若文法G定义的语言是无限集,则文法必然是( )。
A.二义性的B.上下文无关的C.递归的D.无二义性的正确答案:C3、一个上下文无关文法G包括四个组成部分,它们是一组非终结符号,一组终结符号,一个开始符号,以及一组( )。
A.句子B.单词C.产生式D.句型正确答案:C4、文法G:S →x xS | y 所识别的语言是( )。
A.xxy∗B. xx∗yxC.(xxy)∗D.(xx)∗y正确答案:D5、文法G:S →xS | y 所识别的语言是( )。
A.(xy)∗B.xy∗C.x∗yD. xx∗yx正确答案:C6、在自上而下的语法分析中,应从( )开始分析。
A.句型B.句子C.文法开始符号D.句柄正确答案:C7、语法分析器的输入是()。
A.符号表B.目标程序C.源程序D.Token序列正确答案:D8、LL(1)分析法中“1”的含义是在输入串中查看一个输入符号,其目的是()。
A.确定最左推导B.确定是否推导C.确定句柄D.确定使用哪一个产生式进行展开正确答案:D9、同正规式(a|b)∗等价的正规式为( )。
A.a∗|b∗B.(a|b)+C.(ab)∗D.(a∗|b∗)+正确答案:D10、已知文法G[S]:S→A1,A→A1|S0|0,与G等价的正规式是( )。
A.1∗|0∗1B.0(1|10)∗1C.0(0|1)∗D.1(10|01)∗0正确答案:B11、与(a|b)∗(a|b)等价的正规式是( )。
A.a∗|b∗B.(ab)∗(a|b)C.(a|b)(a|b)∗D.(a|b)∗正确答案:C12、如果一个正规式所代表的集合是无穷的,则它必含有的运算是( )。
A.接运算“·”B.或运算“|”C.括号“(”和“)”D.闭包运算“* ”正确答案:D13、在语法分析处理中,FIRST集合、FOLLOW集合均是( )。
编译原理期末考试习题及答案

一、填空题|(每题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 集合。
(完整word版)编译原理期末考试习题及答案(word文档良心出品)

一、填空题| (每题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)⑴ E T | E+T⑵ T F | F*F⑶ 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分)IS/|\7i\E+T(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 ⑵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}六.已知文法G(S):(1) S A | a | (T)⑵ T T,S | S试:(1)消除文法的左递归;(4分)(2) 构造相应的first 和follow 集合。
编译原理考试题及答案

编译原理考试题及答案一、选择题(每题2分,共20分)1. 编译器的主要功能是将高级语言源程序转换成机器语言目标程序。
(对/错)答案:对2. 编译过程中,词法分析器的主要任务是识别源程序中的各种词法单位。
(对/错)答案:对3. 在语法分析阶段,编译器使用的数据结构是栈。
(对/错)答案:错4. 语义分析的主要目的是检查程序的语法结构是否正确。
(对/错)答案:错5. 编译器的优化阶段可以提高目标程序的执行效率。
(对/错)答案:对6. 编译器的代码生成阶段负责将中间代码转换为目标代码。
(对/错)答案:对7. 编译器的运行时系统包括内存管理、输入输出处理等功能。
(对/错)答案:对8. 编译器的前端主要负责源程序的分析,后端负责目标代码的生成。
(对/错)答案:对9. 编译器的词法分析阶段不涉及对标识符的识别。
(对/错)答案:错10. 编译器的语法分析阶段可以识别出所有的语法错误。
(对/错)答案:对二、填空题(每题2分,共20分)1. 编译器在进行语法分析时,通常采用________算法。
答案:LL(1)或LR(1)2. 编译器在语义分析阶段,需要对变量的________进行检查。
答案:作用域和生命周期3. 编译器在代码优化阶段,常用的优化技术包括________和循环优化。
答案:常量传播4. 编译器在目标代码生成阶段,需要考虑________的约束。
答案:目标机器5. 编译器的运行时系统包括________、内存管理、输入输出处理等。
答案:程序启动和异常处理6. 编译器在词法分析阶段,需要识别的词法单位包括________、标识符、常量等。
答案:关键字7. 编译器在语法分析阶段,使用的分析表可以是________表或ACTION 表。
答案:GOTO8. 编译器在语义分析阶段,需要对表达式的________进行计算。
答案:类型9. 编译器的代码生成阶段,需要将中间代码转换为________代码。
答案:目标机器10. 编译器的运行时系统在内存管理中,需要处理________和垃圾收集。
编译原理期末考试复习题(含答案)

编译原理期末考试复习题(含答案)一、选择题1.代码生成阶段的主要任务是(C)。
A.把高级语言翻译成汇编语言B.把高级语言翻译成机器语言C.把中间代码变换成依赖具体机器的目标代码D.把汇编语言翻译成机器语言2.文法G 所描述的语言是( C )的集合。
A.文法G 的字母表V 中所有符号组成的符号串B.文法G 的字母表V 的闭包V* 中的所有符号串C.由文法的开始符号推出的所有终结符串D.由文法的开始符号推出的所有符号串3.语言是(C)。
A.终结符与非终结符的符号串的集合B.非终结符符号串的集合C.终结符符号串的集合D.产生式的集合4.常用的中间代码形式不含(D)。
A.三元式B.四元式C.逆波兰式D.语法树5.四元式之间的联系是通过(B)实现的。
A.指示器B.临时变量C.符号表D.程序变量6.词法分析器的输出结果是( C )。
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.下推自动机识别的语言是( C )A.0型语言 B.1型语言C.2型语言 D.3型语言9. 在规范归约中,用(B)来刻画可归约串。
A.直接短语 B.句柄C.最左素短语 D.素短语10.词法分析器用于识别( C)。
A.字符串 B.语句 C.单词 D.标识符11.一个句型中称为句柄的是该句型的最左(D)A.非终结符号 B.短语 C.句子 D.直接短语12.文法 G[E] :E→T∣E+TT→F∣T * FF→a∣(E)该文法句型 E + F * (E + T) 的简单短语是下列符号串中的(B)。
①(E+T)②E+T ③F ④ F * (E+T)A.①和③B.②和③C.③和④D.③13.通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括(C)。
2023大学_编译原理试题及参考答案

2023编译原理试题及参考答案编译原理试题一、是非题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)(每个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:SxSx|y所识别的语言是_____。
A.( ) xyxB.( ) (xyx)__C.( ) xnyxn(n0)D.( ) x__yx__4.如果文法G是无二义的,则它的任何句子_____。
A.( )最左推导和最右推导对应的语法树必定相同B.( ) 最左推导和最右推导对应的语法树可能不同C.( ) 最左推导和最右推导必定相同D.( )可能存在两个不同的最左推导,但它们对应的语法树相同5.构造编译程序应掌握______。
A.( )源程序B.( ) 目标语言C.( ) 编译方法D.( ) 以上三项都是6.四元式之间的联系是通过_____实现的。
A.( ) 指示器B.( ) 临时变量C.( ) 符号表D.( ) 程序变量7.表达式(┐AB)(CD)的逆波兰表示为_____。
A. ( ) ┐ABCDB.( ) A┐BCDC.( ) AB┐CDD.( ) A┐BCD8. 优化可生成_____的目标代码。
A.( ) 运行时间较短B.( ) 占用存储空间较小C.( ) 运行时间短但占用内存空间大D.( ) 运行时间短且占用存储空间小9.下列______优化方法不是针对循环优化进行的。
A. ( ) 强度削弱B.( ) 删除归纳变量C.( ) 删除多余运算D.( ) 代码外提10.编译程序使用_____区别标识符的作用域。
编译原理期末试题(8套含答案+大题集)

《编译原理》期末试题(一)一、是非题(请在括号内,正确的划√,错误的划×)(每个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.构造编译程序应掌握______。
编译原理期末考试试卷及答案

一. 填空题(每空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中存在一个句子,当其满足下列条件()之一时,则称该文法是二义文法。
编译原理期末考试题目及答案

一、填空题(每空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.一个无限形态自动机中,有且仅有一个独一的终态.x3.一个算符优先文法的每个非闭幕符号间都也可能存在优先关系.X4.语法分析时必须先消弭文法中的左递回 .X6.逆波兰暗示法暗示表达式时无须运用括号.R9.两个正轨集相称的必要条件是他们对应的正轨式等价. X1.编译程序是对高级言语程序的编译执行.X2.一个无限形态自动机中,有且仅有一个独一的初始态.R3.一个算符优先文法的每个非闭幕符号间都不存在优先关系.R4.LL(1)语法分析时必须先消弭文法中的左递回 . R5.LR分析法在自左至右扫描输入串时就能发现错误,但不克不及精确地指出出错地点. R6.逆波兰暗示法暗示表达式时根据表达式会运用括号. X7.静态数组的存储空间可以在编译时确定.X8.进行代码优化时应偏重考虑循环的代码优化,这对进步目的代码的服从将起更大作用.X9.两个正轨集相称的必要条件是他们发生的符号串是相反的. R10.一个语义子程序描绘了一个文法所对应的翻译工作. X1.什么是S-属性文法?什么是L-属性文法?它们之间有什么关系?S-属性文法是只含有综合属性的属性文法. (2分)L-属性文法要求对于每个发生式A X1X2…Xn,其每个语义规则中的每个属性或者是综合属性,或者是Xj的一个承继属性,且该属性仅依赖于:(1)发生式Xj的右边符号X1,X2…Xj-1的属性;(2)A的承继属性. (2分)S-属性文法是L-属性文法的特例.(1分)2.什么是LL(1)分析器2.什么是LR(0)分析器所谓LR(0)分析,是指从左至右扫描和自底向上的语法分析,且在分析的每一步,只须根据分析栈当前已移进和回约出的全部文法符号,并至少再向前检查0个输入符号,就能确定绝对于某一发生式左部符号的句柄能否已在分析栈的顶部构成,从而也就可以确定当前所应采纳的分析动作(是移进还是按某一发生式进行回约等).五、综合题(共40分)1.(10分)对于文法 G[S] :S → 1A | 0B | ε A → 0S | 1AA B → 1S | 0BB⑴ (3 分 ) 请写出三个关于 G[S] 的句子;⑵ (4 分 ) 符号串 11A0S 能否为 G [S] 的句型?试证明你的结论.⑶ (3 分 ) 试画出 001B 关于 G [S] 的语法树.答:(1)三个 0 和 1 数量相称的串(每个1分)(2) S => 1A => 11AA => 11A 0S(3)2.(10分)设有言语 L={ α | α∈ {0,1} + ,且α不以 0 扫尾,但以 00 结尾 } .3分)试写出描绘 L 的正轨表达式;⑵(7分)构造辨认 L 的 DFA (要求给出细致过程,并画出构造过程中的NFA 、 DFA 的形态转换图,以及最小DFA的形态转换图 ) .答:( 1 )(3分)正轨表达式: 1(0|1) * 00( 2 )(7分)第一步(3分):将正轨表达式转换为 NFA第二步(2分):将 NFA 确定化为 DFA :(1分)形态输入I 0 I 1 t 0 1[S] —[A,D,B] q 0 —q 1[A,D,B] [D,B,C] [D,B] q 1 q 2 q 3[D,B,C] [D,B,C,Z] [D,B] q 2 q 4 q 3[D,B] [D,B,C] [D,B] q 3 q 2 q 3[D,B,C,Z] [D,B,C,Z] [D,B] q 4 q 4 q 3DFA 的形态转换图(1分)第三步(2分):将DFA 最小化:(1分)将形态划分终态与非终态两个集合:A={q0,q1,q2,q3},E={q4}根据A、E集合的状况,对A集合进行划分形态输入I 0 I 1q0—Aq1AAq2EAq3AA将形态集A划分为两个集合:A={q0,q1,q3},B={2}根据A、B集合的状况,对A集合进行划分形态输入I 0 I 1q0—Aq1BAq3BA将形态集A划分为两个集合:A={q0},C={q1,q3}根据A、C集合的状况,对C集合进行划分形态输入I 0 I 1q1BAq3BA最小DFA 的形态转换图(1分)3.(20分)给定文法 G[E] :E → E+T | TT → T*F | FF → (E) | i该文法是 LL(1) 文法吗?(要求给出细致过程,假如是LL(1),给出分析表)答:(1)该文法不是LL(1)文法,由于有左递回,消弭左递回可获得一个LL(1)文法(2分)(2)消弭左递回,得新文法 (3分)E → TE’E’→ +TE’| εT → FT’T’→ *FT’ |εF → (E) | i(3)求发生式右部的First集 (2.5分)First(TE’) = First(T)= First(F)={(,i}First(+TE’) = {+}First(FT’) = First(F)={(,i}First(*FT’) = {*}First((E)) = {(}First(i) = {i}(4)求全部非闭幕符的Follow集(2.5分)Follow(E) = {$,)}Follow(E’) = Follow(E) = {$,)}Follow(T) = First(E’)∪Follow(E)={+} ∪{$,)}={$,+,)} Follow(T’) = Follow(T) ={$,*,)}Follow(F) = First(T’)∪Follow(T)∪Follow(T’)= {$,*,)} (5)求全部发生式的Select集 (2.5分)Select(E → TE’)=First(TE’)= {(,i}Select(E’→ +TE’)=First(+TE’)= {+}Select(E’→ε)= Follow(E’) = {$,)}Select(T → FT’)=First(FT’)= {(,i}Select(T’→ *FT’)=First(*FT’)= {*}Select(T’→ε)= Follow(T’) ={$,+,)}Select(F → (E))=First((E))= {(}Select(F → i)=First(i)= {i}(6)对相反左部的全部Select 即求交集(2.5分) Select (E ’→ +TE ’)∩Select (E ’→ε)=Φ Select (T ’→ *FT ’)∩Select (T ’→ε)=Φ Select (F → (E))∩Select (F → i )=Φ以是,改造后的文法是LL (1)文法,其分析表如下 (7) LL(1) 分析表( 5 分)V NV T+ * i ( )$E E → TE ’ E → TE ’ E ’ E ’→ +TE ’ E ’→ε E ’→εT T → FT ’ T → FT ’ T ’ T ’→ε T ’→ *FT ’ T ’→ε T ’→εF F → (E) F → i1.(10分)对于文法G :SaSbS|aS|d证明该文法是二义性文法.答:一个文法,假如存在某个句子有不只一棵语法分析树与之对应,那么称这个文法是二义性文法.(5分)句子aadbd 有两棵语法树(5分,划一棵树给3分).如下图:(6分)(1) (2)由此可知,SaSbS|aS|d 定义的文法是二义性文法.3.(20分)给定一个简单的算术表达式文法 G[E] : E → E+T | T T → T*F | F F → (E) | i该文法是 SLR(1) 文法吗?(要求给出细致过程,假如是SLR 文法,给出分析表) 答:(1) 该文法的拓广文法是: (2分) E ’→E (1)dSSa bSSad SaSSabSddE → E+T (2)E → T (3)T → T*F (4)T → F (5)F → (E) (6)F → i (7)(2)相应的LR(0)的DFA:(10分)(3)冲突与处理 (3分)① I1形态中有移进—规约冲突Follow(E’)={ $ } 不含{ + }可处理移进—规约冲突② I2形态中有移进—规约冲突Follow(E)={ +,),$ } 不含{ * }可处理移进—规约冲突③ I8形态中有移进—规约冲突Follow(E)={ +,),$ } 不含{ * }可处理移进—规约冲突(4) SLR分析表 (5分)二、单项选择题(每小题2分,共20分)1.言语是____C_A.闭幕符与非闭幕符的符号串的集合 B.非闭幕符符号串的集合 C.闭幕符符号串的集合 D.发生式的集合2.编译程序分两阶段工作,前阶段完成的工作是__C___A.词法分析、语法分析和代码优化 B.代码生成、代码优化和词法分析C.词法分析、语法分析、语义分析和两头代码生成D.词法分析、语法分析和代码优化3.一个句型中称为句柄的是该句型的最左CA.句型 B.短语 C.直接短语 D.最左直接短语4.自动机识此外言语是 DA.0型言语 B.1型言语 C.2型言语 D.3型言语5.自动机所完成的义务是从字符串方式的源程序中辨认出一个个具有独立含义的最小语法单位即 BA.字符 B.单词 C.句子 D.句型6.对应Chomsky四种文法的四种言语之间的关系是BA.L0L1L2L3 B.L3L2L1L0C.L3=L2L1L0 D.L0L1L2=L37.词法分析的义务是AA.辨认单词 B.分析句子的含义 C.辨认句子 D.生成目的代码8.经常运用的两头代码方式不含DA.三元式 B.四元式 C.逆波兰式 D.语法树9.代码优化的目的是CA.俭省工夫 B.俭省空间 C.俭省工夫和空间 D.把编译程序进行等价交换10.代码生成阶段的次要义务是CA.把高级言语翻译成汇编言语 B.把高级言语翻译成机器言语C.把两头代码变换成依赖具体机器的目的代码D.把汇编言语翻译成机器言语。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
(5) 的地址4. 在通常的语法分析方法中,()A.算符优先分析法BC.递归下降分析法D5 .经过编译所得到的目标程序是(A.四元式序列B 特别适用于表达式的分析。
.LR分析法.LL (1)分析法)。
.间接三元式序列.机器语言程序或汇编语言程序河南科技大学电信科卷A填空题(每空2分,共20分)1. 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静态存储分配方案和动态存储分配方案,而后者又分为(1)和(2)。
2. 规范规约是最(3)规约。
3. 编译程序的工作过程一般划分为5个阶段:词法分析、(4)、语义分析与中间代码生成,代码优化及另外还有(6)和出错处理。
4 .表达式x+y*z/(a+b)的后缀式为(7)。
5 •文法符号的属性有综合属性和(8)。
6 .假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..2O] 某个元素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 .自右向左6. 一个文法所描述的语言是();描述一个语言的文法是()。
A .如果在文法G 中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。
其最左推导和最右推导相同 B .该句子有两个不同的最左推导 C. E .该句子对应的语法树唯一 卜面() 语法制导翻译中,采用拉链一回填技术。
B.布尔表达式的计算C.条件语句D.循环语句解答题(共60分)1.(共15分)已知文法G[E]:(1)将文法G 改造成LL (1)文法; (5分)构造文法G 中每个非终结符的FIRST 集合及 FOLLOW!合;(5 分)(3)构造LL ( 1)分析表。
(5分)(1)当分析器的输入为aacbb 时,打印的字符串是什么?3分)该句子有两个不同的最右推导D .该句子有两棵不同的语法树i ETE| (E) |i—*|+2. (共 12 分)给定文法 G[S] : S T S(S)| &(1) 给出句子(()())()() 的规范推导过程;(4分)(2) 指出每步推导所得句型的句柄; (4分) (3)画出该句子的语法推导树。
(4分)3. (共8分)在一个移入-规约分析过程中采用以下的语法制导翻译模式,在按一个产生式规约时,立即执行 括号中的动作。
A T aB {print “ 0”; } A T c {print “ 1”; } B T Ab {print “ 2”; }(2) 写出分析过程。
(5分)4. (10分)翻译循环语句 while (a<b) do if (c>d) then x:=y+z。
要求:给出加注释的分析树及四元式序列。
参考以下部分翻译模式:(1) S T if E then M S 1 {backpatch(E.truelist,M.quad);S. nextlist:=merge(E.falselist,S1. nextlist)}(2) S T while M 1 E do M 2 S 1 {backpatch(S1.nextlist,M 1,.quad);8.backpatch(E.truelist,M2, .quad);单项选择题(每题2分,共10分)S T a| A |(T )T T T,S|S(1) 计算文法 G[S]的FIRSTVT 集和LASTVT 集。
(5分)⑵构造G[S]的优先关系表,并判断G[S]是否为算符优先文法。
(5 分)⑶计算G[S]的优先函数。
(5分)1.设有文法 G[I] : I T I1|l0|la|lc|a|b|cS.nextlist:=E.falselistemit ('M .quad)} 5.⑶ S T A⑷L T SMT £⑹ E T idrelop id 1 emit(emit ({S.nextlist:=makelist()} {L.n extlist:=S. nextlist}{M.quad:=n extquad}{E.truelist:=makelist( nextquad);e.falselist:=makelist (n extquad+1);'j 'relop.op, ‘, 'id 1.place ‘, 'id 2.place ‘, ''O'); j ,-,-,0 ')}(8)T L:=E{emit(:=,E.place,-, L.place)}{E.place:=newtemp;emit(+,E1.place,E2.place,E.place,)}(共15分)设有表格构造文法 G[S]:①ab0 ② a0c01③aaa可选项有:A.①B .②③④C. ③④2.程序的基本块是指( 、 )。
F 列符号串中是该文法句子的有()。
A. 一个子程序 B ④ bc10D .①②③④一个仅有一个入口和一个出口的语句)分析方法。
。
要求:给出加注释的分析树、三地址3.高级语言编译程序常用的语法分析方法中,递归下降分析法属于(4 .经过编译所得到的目标程序是( A.四元式序列 B C. 二元式序列 D)。
.间接三元式序列.机器语言程序或汇编语言程序b| &(4) 构造其LL (1)分析表;(5)判断符号串baabbb 是否为该文法的句子(写出含有符号栈、输入串和规则的分析过程)。
3. (10 分)已知文法 G 为:i E+T|TT*P|PP T i(1) 构造该文法的优先关系表(不考虑语句括号 #),并指出此文法是否为算符优先文法。
(2)构造文法G 的优先函数表。
4.(8分)在一个移入-规约分析过程中采用以下的语法制导翻译模式,在按一个产生式规约时,立即执行括 号中的动作。
S T bAb {print “ 1 ”} A T (B {print “ 2”} AT a {print“ 3”} B T Aa) {print“ 4” }(3) 当输入序列为b(((aa)a)a)b 时,打印的字符串是什么?(4)写出移入-规约分析过程。
5.(12 分)翻译循环语句 while (x>y) do if (a=b) then x:=2*y+aA.自左向右 B .自顶向下 C自底向上 D自右向左①提高编译程序的运行速度 ② ③ 提高目标程序的运行速度④ 可选项有 :A.①②B. ②③C.得分2.(10分)已知文法S T aBc|bAB5. 运行阶段的存储组织与管理的目的是()。
节省编译程序的存储空间 为运行阶段的存储分配做准备③④ D. ④②G[S]:A^ aAb|b码序列及相应的四元式序列。
参考以下部分翻译模式:(1 ) S f if E then M S 1 {backpatch(E.truelist,M.quad);S.nextlist:=merge(E.falselist,S 1 .nextlist)}(2)S f while M 1 E do M 2 S 1 {backpatch(S 1.nextlist,M 1,.quad);backpatch(E.truelist,M 2,.quad);S.nextlist:=E.falselistemit ( ‘ j,-,-, 'M1 .quad)}(3)S f A {S.nextlist:=makelist()}(4)L f S {L.nextlist:=S.nextlist}(5)M f £{M.quad:=nextquad}(6 ) E f id 1 relop id 2{E.truelist:=makelist(nextque.falselist:=makelist(nextquad+1);emit( ‘ j 'relop.op, ‘, 'id 1.place ‘, 'id 2.place ‘, '‘ 0'emit( ‘j,-,-,0 ')}(7) S f L:=E {emit(:=,E.place,-,L.place)}(8) E f E1+E2 {E.place:=newtemp;emit(+,E 1.place,E 2.place,E.place,)}6. (8 分 ) Generate assembly code for the following sequence assuming that x,y and z are in memorylocations(noticing only two registers R1 and R2).S=0I=0L1: if x>y goto L2Z=s+a[i]I=i+1Goto L1L2:7.(6 分) Give out the all basic blocks of the following program fragment and construct the relevant flow graph(DAG).read CA=0B=1L4: A=A+Bif B>C goto L2B=B+1goto L4L2: write A8. (8 分)Translate the assignment statement b[i]=b*c-b*d into(1) A syn tax tree.(2) Three address in struct ions.答案::(1) 栈式动态存储分配(2) 堆式动态存储分配⑶左(4) 语法分析(5) 目标代码生成(6) 表格管理(7) xyz*ab+/+(8) 继承属性(9) a+(i-1)*20+j-1(10) 基本块一、选择题(每问2分,共20分)1.C B2.D3.B4.A5.D6.A,C7. BCD,选对一个得1分且不超过满分,选错一个扣一分,扣完为止8. BCD,选对一个得1分且不超过满分,选错一个扣一分,扣完为止二、解答题1. (1)文法存在左递归,消除左递归后的文法为:E T (E)E '|i E ' ( 2 分)E'T TEE | £(2 分)T T *|+ (1 分)(2) (5分)没考虑#扣0.5分,其它错或少写一个扣0.5分FIRST(E)={(,i} FIRST(E ')={*,+, £ } FIRST(T)={*,+}FOLLOW(E)={),*,+,#} FOWLLOW(E ')= {),*,+,#} FOLLOW(T)={(,i}S ( S )£分,共4分。