编译原理期末复习题

合集下载

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

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

编译原理期末考试试题及答案一、选择题(每题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. 静态作用域规则是指变量的作用域在编译时确定,而动态作用域规则是指变量的作用域在运行时确定。

编译原理期末复习题

编译原理期末复习题

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) T3.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表示除这五个元音外的其它字母。

《编译原理》期末复习题

《编译原理》期末复习题

《编译原理》期末复习题一、简答题1.DFA和NFA的区别是什么?答:dfa与nfa的区别表现为两个方面:一是nfa可以若干个开始状态,而dfa仅只一个开始状态。

另一方面,dfa的映象m是从k×∑到k,而nfa的映象m是从k×∑到k的子集,即映象m将产生一个状态集合(可能为空集),而不是单个状态。

2、何谓优化?按所涉及的程序范围可分为哪几级优化?1)优化:对程序进行各种等效转换,以便从转换后的程序开始,生成更有效的目标代码。

(2)三个层次:局部优化、循环优化和全局优化。

3.短语、简单短语和句柄之间的关系?语法树子树的末端节点符号串既是语法树所描述与对子子树的根的短语;简单子树的标点符号串既是简单短语;最左简单子树的末端符合既是句柄。

4、语法分析的任务是什么?输入、输出分别是什么?任务是在词法分析识别出单词符号串的基础上。

分析并判定程序的语法结构是否符合语法规则;输入:源程序;输出:单词符号串。

5.静态链和动态链分别存储哪些值?为了什么?静态链是指向静态直接外层最新活动记录地址的指针,作用是用来访问非局部数据;动态链是指向调用该过程前的最新活动记录的指针。

作用是运行时使运行栈上个数据区按动态建立次序结成链。

6.综合属性和继承属性的区别是什么?它的值在语法树中的传递方向是什么?区别:综合属性用于自上而下传递信息,继承属性用于自上而下传递信息。

方向:在语法树中,一个节点的综合属性的值由其子节点的综合属性值决定;一个节点的继承属性由此节点的父节点和/或兄弟节点的属性确定的。

7.什么是优化?优化效果的两个方面是什么?对程序进行各种等价变换,使得从变化后的程序出发,能生成更有效的目标代码。

通称为优化。

①、在目标代码生成以前,对语法分析后的中间代码进行的,这类优化不依赖于具体的计算机;②、在目标代码生成时进行的,它在很大程度上依赖于具体的计算机。

8、编译程序和解释程序的区别?哪个更通用?区别:编译器是一种程序,其中源语言是高级语言,目标语言是汇编语言或机器语言的低级语言。

编译原理期末考试复习题

编译原理期末考试复习题

选择:1.编译程序绝大多数时间花在 D 上。

a.出错处理b.词法分析c.目标代码生成d.管理表格3.如果文法G是无二义的,则它的任何句子α A 。

a. 最左推导和最右推导对应的语法树必定相同b. 最左推导和最右推导对应的语法树可能不同c. 最左推导和最右推导必定相同d. 可能存在两个不同的最左推导,但它们对应的语法树相同4.在规范归约中,用 B 来刻画可归约串。

a. 直接短语b. 句柄c. 最左素短语d. 素短语5.若a为终结符,则A→α·aβ为 B 项目a.归约b.移进c.接受d.待约6.间接三元式表示法的优点为(A)A.采用间接码表,便于优化处理B.节省存储空间,不便于表的修改C.便于优化处理,节省存储空间D.节省存储空间,不便于优化处理7.下列C优化方法不是针对循优化进行的。

a.强度削弱b.删除归纳变量c.删除多余运算d.代码外提8.过程P1调用P2时,连接数据不包含 A 。

a. 嵌套层次显示表b. 老SPc. 返回地址d. 全局DISPLAY地址9.如果活动记录中没有DISPLAY表,则说明b。

a. 程序中不允许有递归定义的过程b. 程序中不允许有嵌套定义的过程c. 程序中既不允许有嵌套定义的过程,也不允许有递归定义的过程d. 程序中允许有递归定义的过程,也允许有嵌套定义的过程10.关于必经结点的二元关系,下列叙述中不正确的是 D 。

a.满足自反性b.满足传递性c.满足反对称性d.满足对称性11.构造编译程序应掌握 D 。

a.源程序b.目标语言c.编译方法d.以上三项都是12.词法分析器的输出结果是__C___。

A.单词的种别编码B.单词在符号表中的位置C.单词的种别编码和自身值D.单词自身值13.文法G:S→xSx|y所识别的语言是 C 。

a. xyxb. (xyx)*c. x n yx n(n≥0)d. x*yx*14.同心集的合并有可能产生新的归约/归约冲突15.四元式之间的联系是通过 B 实现的。

编译原理期末考试复习题

编译原理期末考试复习题
6.削减运算强度破坏了临时变量在一基本块内仅被定义一次的特性。(Y )
7.在中间代码优化中循环上的优化主要有不变表达式外提和削减运算强度。(N )
8.算符优先关系表不一定存在对应的优先函数。( N)
9.数组元素的地址计算与数组的存储方式有关。(N )
10.编译程序与具体的机器有关,与具体的语言无关。(N )
SELECT(F'->*F')={*};
SELECT(F'->ε)=FOLLOW(F')={(,a,b,^,+,),#};
SELECT(P->(E))={(}
SELECT(P->a)={a}
SELECT(P->b)={b}
SELECT(P->^)={^}
可见,相同左部产生式的SELECT集的交集均为空,所以文法G[E]是LL(1)文法。
A.候选式B.句型C.单词D.产生式
5.文法G[E]:
E→T∣E+T
T→F∣T﹡F
F→a∣(E)
该文法句型E+F﹡(E+T)的简单短语是下列符号串中的_____。
①(E+T)②E+T③F④F﹡(E+T)
A.①和③B.②和③C.③和④D.③
6.若一个文法是递归的,则它所产生的语言的句子_____。
A.( )是无穷多个B.( )是有穷多个
参考答案:
解:根据题意有NFA图:
下表由子集法将NFA转换为DFA:
下面将该DFA最小化:
(1)首先将它的状态集分成两个子集:P1={A,D,E},P2={B,C,F}
(2)区分P2:由于F(F,1)=F(C,1)=E,F(F,0)=F并且F(C,0)=C,所以F,C等价。由于F(B,0)=F(C,0)=C, F(B,1)=D,F(C,1)=E,而D,E不等价(见下步),从而B与C,F可以区分。有P21={C,F},P22={B}。

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

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

一、填空题(每空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___实现的。

编译原理 期末复习

编译原理 期末复习

编译原理一、单选题1、将编译程序分为若干个“遍”是为了()。

BA.提高程序的执行效率B.使程序的结构更加清晰C.利用有限的机器内存并提高机器的执行效率D.利用有限的机器内存但降低了机器的执行效率2、构造编译程序应掌握()。

DA.源程序B.目标语言C.编译方法D.以上三项都是3、变量应当()。

CA.持有左值B.持有右值C.既持有左值又持有右值D.既不持有左值也不持有右值4、编译程序绝大多数时间花在()上。

DA.出错处理B.词法分析C.目标代码生成D.管理表格5、()不可能是目标代码。

DA.汇编指令代码B.可重定位指令代码C.绝对指令代码D.中间代码6、编译程序是对()。

DA.汇编程序的翻译B.高级语言程序的解释执行C.机器语言的执行D.高级语言的翻译7、正规式M1和M2等价是指()。

CA.M1和M2的状态数相等B.M1和M2的有象弧条数相等C.M1和M2所识别的语言集相等D.M1和M2状态数和有象弧条数相等8、如果文法G是无二义的,则它的任何句子()。

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

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

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

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

9、文法G:S→S+T|TT→T*P|PP→(S)|i句型P+T+i的短语有()BA.i,P+TB. P,P+T,i,P+T +iB.P+T + i D. P,P+T,i10、产生正规语言的文法为()。

DA.0型B.1型C.2型D.3型11、文法G:S→b|˄|(T)T→T˅S|S则FIRSTVT(T)=() CA.{b,˄,(}B.{b,˄,)}C.{b,˄,(,˅}D.{b,˄,),˅}12、给定文法:A→bA | cc,下面的符号串中,为该文法句子的是()。

A①cc ②bcbc ③bcbcc ④bccbcc ⑤bbbcc可选项有:A.①B.①③④⑤C.①④D.①④⑤13、采用自上而下分析,必须()。

编译原理期末复习题(包含上一份N多答案)

编译原理期末复习题(包含上一份N多答案)

编译原理复习题一、填空题: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、在编译过程中,常见的中间语言形式有(逆波兰表示)、(三元式)、(四元式)和(树形表示)。

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

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

第八节习题一、单项选择题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二、多项选择题1、编译程序各阶段的工作都涉及到bc 。

a.语法分析b.表格管理c.出错处理d.语义分析e.词法分析2、编译程序工作时,通常有abce 阶段。

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

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

《编译原理》期末考试复习题一、是非题(请在括号内,正确的划√,错误的划×)(每个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*} 。

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

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

第八节习题-、单项选择题1、 __________________________________________________ 将编译程序分成若干个“遍”是为了_____________________________________a .提高程序的执行效率b •使程序的结构更加清晰c .利用有限的机器内存并提高机器的执行效率d •利用有限的机器内存但降低了机器的执行效率2、构造编译程序应掌握。

a •源程序c .编译方法3、变量应当_________ 。

a .持有左值c .既持有左值又持有右值4、编译程序绝大多数时间花在a .出错处理c •目标代码生成5、_______ 不可能是目标代码。

a •汇编指令代码c •绝对指令代码b.目标语言d.以上三项都是b.持有右值d.既不持有左值也不持有右值 _______ 上。

b.词法分析d.管理表格b.可重定位指令代码d.中间代码6、使用可以定义一个程序的意义。

a .语义规则 b.词法规则c .产生规则 d.词法规则7、词法分析器的输入是___________ 。

a .单词符号串 b.源程序c .语法单位 d. 目标程序8、 中间代码生成时所遵循的是 - _______ 。

b.词法规则 d.等价变换规则a .语法规则 c .语义规则c .机器语言的执行d.高级语言的翻译10、语法分析应遵循d.等价变换规则 解答1、 将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选 b 。

2、 构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选 d 。

3、 对编译而言,变量既持有左值又持有右值,故选 c 。

4、 编译程序打交道最多的就是各种表格,因此选 do5、 目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码 3种,因此不是目标代码 的只能选do6、 词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规 则,并且语义规则可以定义一个程序的意义。

编译原理期末试题及答案

编译原理期末试题及答案

编译原理期末试题及答案一、选择题(每题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. 语法分析阶段,如果一个文法是左递归的,编译器需要使用()技术来消除左递归。

编译原理试题及答案(期末复习版)

编译原理试题及答案(期末复习版)

<编译原理>历年试题及答案一.(每项选择2分,共20分)选择题1.将编译程序分成若干个“遍”是为了_b__。

a.提高程序的执行效率b.使程序的结构更加清晰c.利用有限的机器内存并提高机器的执行效率d.利用有限的机器内存但降低了机器的执行效率2.构造编译程序应掌握__d__。

a.源程序b.目标语言c.编译方法d.以上三项都是3.变量应当c_。

a.持有左值b.持有右值c.既持有左值又持有右值d.既不持有左值也不持有右值4.编译程序绝大多数时间花在_d___上。

a.出错处理b.词法分析c.目标代码生成d.管理表格5.词法分析器的输出结果是_c___。

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

a.MI和M2的状态数相等b.Ml和M2的有向弧条数相等。

C.M1和M2所识别的语言集相等 d.Ml和M2状态数和有向弧条数相等7.中间代码生成时所依据的是—c。

a.语法规则b.词法规则c.语义规则d.等价变换规则8.后缀式ab+cd+/可用表达式__b_来表示。

a.a+b/c+d b.(a+b)/(c+d)c.a+b/(c+d)d.a+b+c/d9.程序所需的数据空间在程序运行前就可确定,称为____c__管理技术。

a.动态存储b.栈式存储c.静态存储d.堆式存储10.堆式动态分配申请和释放存储空间遵守___d_____原则。

a.先请先放b.先请后放c.后请先放d.任意二(每小题10分,共80分)简答题1.画出编译程序的总体结构图,简述各部分的主要功能。

2.已知文法G[E]:E→ET+|T T→TF*|F F→F^|a试证:FF^^*是文法的句型,指出该句型的短语、简单短语和句柄.3.为正规式(a|b)*a(a|b)构造一个确定的有限自动机。

4.设文法G(S):S→(L)|a S|aL→L,S|S(1)消除左递归和回溯;(2)计算每个非终结符的FIRST和FOLLOW;(3)构造预测分析表。

编译原理期末复习题

编译原理期末复习题

编译原理期末复习题⼀、单项选择题1.构造编译程序应掌握。

Da. 源程序b. ⽬标语⾔c. 编译⽅法d. 以上三项都是 2.编译程序绝⼤多数时间花在上。

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

Da. 以0开头的⼆进制数组成的集合b. 以0结尾的⼆进制数组成的集合c. 含奇数个0的⼆进制数组成的集合d. 含偶数个0的⼆进制数组成的集合4. -a-(b*c/(c-d)+(-b)*a)的逆波兰表⽰是。

(@代表后缀式中的求负运算符) Ca. abc*cd-b@a*+/-@b. a@bc*cd-b@a*+/-c. a@bc*cd-/b@a*+-d. a@bc*/cd-b@a*+- 5.在规范归约中,⽤来刻画可归约串。

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

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

Ca. 语法规则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其值为。

Ca. 10b. 34c. 14d.54 9.如果⽂法G 是⽆⼆义的,则它的任何句⼦α。

A1图1-1a. 最左推导和最右推导对应的语法树必定相同b. 最左推导和最右推导对应的语法树可能不同c. 最左推导和最右推导必定相同d. 可能存在两个不同的最左推导,但它们对应的语法树相同10.下列动作中,不是⾃下⽽上分析动作的是:。

编译原理期末试题(8套含答案)资料

编译原理期末试题(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.( ) x n yx n(n≥0) D.( ) x*yx*4.如果文法G是无二义的,则它的任何句子α_____。

A.( )最左推导和最右推导对应的语法树必定相同B.( ) 最左推导和最右推导对应的语法树可能不同C.( ) 最左推导和最右推导必定相同D.( )可能存在两个不同的最左推导,但它们对应的语法树相同5.构造编译程序应掌握______。

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

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

编译原理期末考试复习题(含答案)一、选择题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)。

编译原理期末试题及答案

编译原理期末试题及答案

1、试为表达式 w+(a+b)*(c+d/(e-10)+8) 写出相应的逆波兰表示。

2、写出表达式a+b*(c-d)/e的逆波兰式和三元序列。

3、写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列。

4、已知文法G(S)及相应翻译方案S→aAb {print “1”}S→a {print “2”}A→AS {print “3”}A→c {print “4"}输入acab, 输出是什么?5、已知文法G(S)S→bAaA→(B | aB→A a)写出句子b(aa)b的规范归约过程.6、已知文法G[S]S→S*aF | aF |*aFF→+aF | +a消除文法左递归。

1、设文法G(S):S→^ | a | (T)T→T,S | S⑴ 消除左递归;⑵ 构造相应的FIRST和FOLLOW集合;⑶ 构造预测分析表2.语句 if E then S(1)改写文法,使之适合语法制导翻译;(2)写出改写后产生式的语义动作。

4。

设某语言的for语句的形式为for i:=E(1) to E(2) do S其语义解释为i:=E(1)LIMIT:=E(2)again: if i<=LIMIT thenBeginS;i:=i+1goto againEnd;(1)写出适合语法制导翻译的产生式;(2)写出每个产生式对应的语义动作。

7。

已知文法G(S)S→a | ^ | (T)T→T,S | S(1) 给出句子(a,(a,a))的最左推导;(2) 给出句型((T,S),a)的短语, 直接短语,句柄。

8。

对于 C 语言do S while E语句(1)改写文法,使之适合语法制导翻译;(2)写出改写后产生式的语义动作.9。

已知文法G(S)S→aAcBeA→Ab| bB→d(1)给出句子abbcde的最左推导及画出语法树;(2)给出句型aAbcde的短语、素短语。

10。

设文法G(S):S→(T) | aS | aT→T,S | S⑴消除左递归和提公共左因子;⑵构造相应的FIRST和FOLLOW集合;⑶构造预测分析表。

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

编译原理期末试题(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.计算机高级语言翻译成低级语言只有解释一种方式。

()×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*} 。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

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) T3.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(5) [分析]设S是符合要求的串,|S|=2k+1 (k≥0)。

则S→S10|S21,|S1|=2k (k>0),|S2|=2k (k≥0)。

且S1是{0,1}上的串,含有奇数个0和奇数个1。

S2是{0,1}上的串,含有偶数个0和偶数个1。

考虑有一个自动机M1接受S1,那么自动机M1如下:和L(M1)等价的正规表达式,即S1为:((00|11)|(01|10)(00|11)*(01|10))*(01|10)(00|11)*类似的考虑有一个自动机M2接受S2,那么自动机M2如下:和L(M2)等价的正规表达式,即S2为:((00|11)|(01|10)(00|11)*(01|10))*因此,S为:((00|11)|(01|10)(00|11)*(01|10))*(01|10)(00|11)*0| ((00|11)|(01|10)(00|11)*(01|10))*1(6)1*|1*0(0|10)*(1|ε)(7)接受w的自动机如下:对应的正规表达式:(1(01*0)1|0)*3.6给出接受下列在字母表{0,1}上的语言的DFA。

(1) 所有以00结束的符号串的集合。

(2) 所有具有3个0的符号串的集合。

答案(a) DFA M=({0,1},{q0,q1,q2},q0,{q2},δ)其中δ定义如下:δ(q0,0)=q1δ(q0,1)=q0δ(q1,0)=q2δ(q1,1)=q0δ(q2,0)=q2δ(q2,1)=q0(b)正则表达式: 1*01*01*01*DFA M=({0,1},{q0,q1,q2,q3},q0,{q3},δ)其中δ定义如下:δ(q0,0)=q1δ(q0,1)=q0δ(q1,0)=q2δ(q1,1)=q1δ(q2,0)=q3δ(q2,1)=q2δ(q3,1)=q33.7构造等价于下列正规表达式的有限自动机。

(1)10|(0|11)0*1(2)((0|1)*|(11))*答案(1)DFA M=({0,1},{q0,q1,q2,q3},q0,{q3},δ)其中δ定义如下:(2)δ(q0,0)=q1δ(q0,1)=q2(3)δ(q1,0)=q1δ(q1,1)=q3(4)δ(q2,0)=q3δ(q2,1)=q1(5)(6)(2) DFA M=({0,1},{q0},q0,{q0},δ)(7)其中δ定义如下:(8)δ(q0,0)=q0δ(q0,1)=q0(9)3.8给定右线性文法G:S->0S|1S|1A|0BA->1C|1B->0C|0C->0C|1C|0|1试求一个于G等价的左线性文法G'3.9试对于下列正规表达式使用证明定理3。

5的构造算法构造非确定的有限自动机。

请给出每个自动机在处理输入符号串ababbab的过程中的动作序列。

(1) (a|b)*(2) (a*|b*)*(3) ((ε|a)b*)*3.10转换练习3.9中的每个 NFA 为 DFA 。

并给出每个DFA在处理输入符号串ababbab的过程中的动作序列。

3.11试把练习3.10中得到的DFA的状态给以最小化。

答案(1),(2),(3)的DFA M 相同,化简结果为:(4)3.12 我们可以证明两个正规表达式是等价的,如果它们的最小状态DFA 是相同的(除了状态的名字以外)。

利用这一结论,请说明下列正规表达式都是等价的。

(1) (a|b)*(2) (a *|b *)*(3) ((ε|a)b *)*答案根据3.11的结果知这几个正规表达式是等价的。

3.13 对于下列正规表达式构造最小状态的DFA 。

(1) (a|b)*a(a|b) (2) (a)b)*a(a|b)(a|b) 5. 对如下文法:G [S] : S → a b S | a a B | a dB → b b B | b分别给出句子abaabbb 和ad 的句柄 句子ad 的语法分析树为:句子abaabbb 的语法分析树为:Sa d所以句子abaabbb的句柄是b;句子ad的句柄是ad .二、(10分)说明如下文法是否是LL(1)文法,若不是,将其转换为LL(1)文法。

最后给出该文法的LL(1)分析表。

G[A]:A → B eB → B b | a文法中有左递归,不是LL(1)文法。

转换为 G′: A→ B eB→ a B′B′→b B′ | λPredict(A→ B e) ={ a }Predict(B→ a B′) ={ a }Predict(B′→b B′) ={ b }Predict(B′→λ ) ={ e }LL(1)分析表:4. 给出识别正则表达式((a|bc)*d)+的NFA 。

5.已知文法G[S]:S → S;G│GG → G(T)│ HH → a │ (S)T → T+S │ S找出句型:a(T+S);H;(S)的短语、简单短语和句柄。

短语: a, T+S, a(T+S) , H , a(T+S);H , (S)简单短语:a , T+S , H , (S) 句柄是 a .6.已知文法G[S]为:S→AB | bC A→b | λB→aD | λC→AD | bD→aS | c对其每一个非终级符求First集和Follow集。

First (S) = { b , a , λ }First (A) = { b , λ }First (B) = { a , λ }First (C) = { b , a , c }First (D) = { a , c }Follow (S) = { # }Follow (A) = { a , c , #}Follow (B) = { # }Follow (C) = { # }Follow (D) = { # }二、(10分)设有文法G[A]: A → iB*eB → SB|εS → [eC]|.iC → eC|ε判定该文法是否为LL(1)文法?若是则给出它的LL(1)分析表,否则说明理由。

先计算各个产生式的Predict集:Predict (A-> iB*e)={ i };Predict (B-> SB) ={ [ , .}Predict (B->ε ) ={ * }Predict (S->[eC]) ={ [ }Predict (S->. i) ={ . }Predict (C-> eC) ={ e }Predict (C->ε ) ={ ] }因为Predict集没有冲突,所以是LL(1)文法。

LL(1)分析表如下:i * e [ ] .A -> iB*e -> εB ->S B ->S BS ->[e C] ->. iC ->eC -> ε1、证明下面文法是LL(1)的但不是SLR(1)文法S→AaAb|BbBa A→εB→ε解:对于产生式S→AaAb|BbBa 来说FIRST(AaAb)∩FIRST(BbBa)={a}∩{b}=Φ而A,B∈V N仅有一条候选式。

因此,这个文法是LL(1)的。

下面构造这个文法的识别活前缀的DFA。

I0= {S'→·S, S→·AaAb, S→·BbBa, A→·, B→·}I1= {S'→S·}I2= {S→A·aAb}I3= {S→B·bBa}I4= {S→Aa·Ab, A→·}I5= {S→Bb·Ba, B→·}I6= {S→AaA·b}I7= {S→BbB·a}I8= {S→AaAb·}I9= {S→BbBa·}由于FOLLOW(A)=FOLLOW(B)={a, b}因此项目集I0中存在归约-归约冲突。

在I0状态下,当输入符号是a或是b时,不知用A→ε还是B→ε进行归约。

故此文法不是SLR(1)的。

但是,此文法是LR(1)的。

五、已知文法G[S],其产生式如下: S→(L)|a L→ L,S|S从G[S]中消除左递归,并为之构造一个非递归预测分析器LL(1)分析表。

请说明在句子(a,(a,a))上的分析器的动作。

(20分)解:将所给文法消除左递归得G': S →(L)|a L → SL' L'→,SL' | ε实现预测分析器的不含递归调用的一种有效方法是使用一分析表和一个栈进行联合控制,下面构造预测分析表:根据文法G'有FIRST(s) = { ( , a ) FOLLOW(S) = { } , ', ' , $ }FIRST(L) = { ( , a ) FOLLOW(L) = { } } FIRST(L’) = { ', ' }FOLLOW(L’) = { } }按以上结果,构造预测分析表M如下:文法G’是LL(1)的,因为它的LL(1)分析表不含多重定义入口。

相关文档
最新文档