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

合集下载

编译原理期末试题及答案

编译原理期末试题及答案

编译原理期末试题及答案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集合;⑶构造预测分析表。

编译原理考试试题及答案

编译原理考试试题及答案

编译原理考试试题及答案 一、选择题(每题2分,共10分) 1. 编译器的主要功能是将高级语言源程序翻译成( )。 A. 机器语言程序 B. 汇编语言程序 C. 中间代码 D. 可执行文件 答案:A

2. 在编译原理中,词法分析的主要任务是( )。 A. 将源代码转换成中间代码 B. 识别源代码中的单词符号 C. 生成语法树 D. 优化代码 答案:B

3. 下列哪个选项不属于语法分析的范畴?( ) A. 构建语法树 B. 词法分析 C. 消除左递归 D. 检测语法错误 答案:B

4. 在编译过程中,语义分析的主要任务是( )。 A. 检查语法结构的正确性 B. 检查标识符的声明和使用 C. 计算表达式的值 D. 代码优化 答案:B 5. 编译器的优化阶段主要关注( )。 A. 语法结构的检查 B. 代码的生成 C. 程序运行效率的提升 D. 错误信息的报告 答案:C

二、填空题(每题2分,共10分) 1. 编译器前端的主要工作包括词法分析、语法分析和________。 答案:语义分析

2. 编译器后端的主要工作包括代码生成和________。 答案:代码优化

3. 在编译原理中,________是指一个非终结符可以推导出空串。 答案:产生式

4. 编译过程中,________分析用于检测和报告语法错误。 答案:语法

5. 编译器中的________分析阶段负责将源代码中的标识符与它们的定义关联起来。 答案:语义

三、简答题(每题10分,共20分) 1. 简述编译器的主要组成及其功能。 答案:编译器主要由前端和后端组成。前端包括词法分析、语法分析和语义分析,负责将源代码转换为中间代码,并进行错误检测和类型检查。后端包括代码生成和代码优化,负责将中间代码转换为目标代码,并优化代码以提高程序的运行效率。 2. 描述编译过程中词法分析器的主要任务。 答案:词法分析器的主要任务是将源代码分解成一系列的标记(token),这些标记包括关键字、标识符、常量、运算符等。它还负责识别和报告源代码中的词法错误,如拼写错误和不匹配的括号等。

编译原理期末试题及答案

编译原理期末试题及答案

编译原理期末试题及答案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→Aa)写出句⼦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 thengoto 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集合;⑶构造预测分析表。

《编译原理》期末考试题库含答案.docx

《编译原理》期末考试题库含答案.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. _________________________________________ 解释程序处理语言时,大多数采用的是 ___________________________________ 方法。

南航编译原理05-06期末考试试题及答案

南航编译原理05-06期末考试试题及答案

南航编译原理05-06期末考试试题及答案一、选择题(每题5分,共25分)1. 编译程序的基本任务是将()转换成()。

A. 高级语言,低级语言B. 低级语言,高级语言C. 源程序,目标程序D. 目标程序,源程序答案:C2. 下列关于词法分析的叙述,错误的是()。

A. 词法分析是编译过程的第一阶段B. 词法分析的任务是识别单词符号C. 词法分析会产生词法错误D. 词法分析不需要考虑上下文答案:D3. 在编译原理中,文法的开始符号是()。

A. 终结符B. 非终结符C. 产生式D. 转换规则答案:B4. 下列关于语法制导翻译的叙述,正确的是()。

A. 语法制导翻译方法适用于所有类型的高级语言B. 语法制导翻译方法具有较高的翻译效率C. 语法制导翻译方法不能很好地处理上下文关系D. 语法制导翻译方法不需要考虑语法分析答案:B5. 下列关于编译程序优化技术的叙述,错误的是()。

A. 优化可以改善目标代码的运行效率B. 优化可以提高编译速度C. 优化可以在不改变程序功能的前提下进行D. 优化可能导致目标代码的运行结果发生变化答案:D二、填空题(每题5分,共25分)1. 编译程序分为________、________和________三个阶段。

答案:词法分析、语法分析、语义分析2. 在编译过程中,词法分析器会生成________。

答案:单词符号3. 在编译原理中,上下文无关文法用________表示。

答案:BNF(巴科斯-诺尔范式)4. 编译程序中的中间代码生成阶段主要完成的任务是________。

答案:生成中间代码5. 常见的编译程序优化技术包括________、________和________。

答案:循环优化、数据流优化、控制流优化三、判断题(每题5分,共25分)1. 编译程序是将源程序转换为机器语言的程序。

()答案:正确2. 词法分析器只需要识别单词符号,不需要考虑上下文。

()答案:正确3. 在编译原理中,上下文无关文法是描述程序语言的最好方法。

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

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

编译原理期末复习题及答案# 一、选择题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.利用有限的机器内存但降低了机器的执行效率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、语法分析应遵循。

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、编译程序各阶段的工作都涉及到。

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

a.词法分析b.语法分析c.中间代码生成d.语义检查e.目标代码生成解答1.b、c 2. a、b、c、e三、填空题1、解释程序和编译程序的区别在于。

[高命中]编译原理期末试题及答案

《编译原理》期末试题(一) 一、是非题(请在括号内,正确的划√,错误的划×)(每个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.( )源程序 B.( ) 目标语言 C.( ) 编译方法 D.( ) 以上三项都是 6.四元式之间的联系是通过_____实现的。 A.( ) 指示器 B.( ) 临时变量 C.( ) 符号表 D.( ) 程序变量 7.表达式(┐A∨B)∧(C∨D)的逆波兰表示为_____。 A. ( ) ┐AB∨∧CD∨ B.( ) A┐B∨CD∨∧ C.( ) AB∨┐CD∨∧ D.( ) A┐B∨∧CD∨ 8. 优化可生成_____的目标代码。 A.( ) 运行时间较短 B.( ) 占用存储空间较小 C.( ) 运行时间短但占用内存空间大 D.( ) 运行时间短且占用存储空间小 9.下列______优化方法不是针对循环优化进行的。 A. ( ) 强度削弱 B.( ) 删除归纳变量 C.( ) 删除多余运算 D.( ) 代码外提 10.编译程序使用_____区别标识符的作用域。 A. ( ) 说明标识符的过程或函数名 B.( ) 说明标识符的过程或函数的静态层次 C.( ) 说明标识符的过程或函数的动态层次 D. ( ) 标识符的行号 三、填空题(每空1分,共10分) 1.计算机执行用高级语言编写的程序主要有两种途径:___解释__和__编译___。 2.扫描器是__词法分析器___,它接受输入的__源程序___,对源程序进行___词法分析__并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。

编译原理期末测试练习题及答案

一、单选题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集合均是( )。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
2.(1)规范推导过程如下。写错推导符号扣0.5分,错写或少写一步推导扣0.5分,扣完为止,最左推导扣2分,共4分。
(2)(1)中加下划线的部分是句柄,标识如(1)。每少写一个句柄扣0.5分,扣完为止,共4分。
(3)每少写步扣0.5分,扣完为止,共4分。
3.(1)打印的字符串是:12020(错一个扣0.5分,共3分)
FOLLOW(E)={),*,+,#} FOWLLOW(E’)= {),*,+,#} FOLLOW(T)={(,i}
(3)每错一个扣0.5分,全错或不写不得分,扣完为止,共5分
(
)
i
*
+
#
E
E→(E)E’
E→iE’
E’
E’→ ε
E’→TEE’
E’ →ε
E’→TEE’
E’ →ε
E’ →ε
T
T→*
T→+
5.语法分析器的输入是( ),其输出是( )。
6.扫描器的任务是从( )中识别出一个个( )。
7.符号表中的信息栏中登记了每个名字的有关的性质,如( )等等。
8.一个过程相应的DISPLAY表的内容为( )。
9.一个句型的最左直接短语称为句型的( )。
10.常用的两种动态存贮分配办法是( )动态分配和( )动态分配。
11.一个名字的属性包括( )和( )。
12.常用的参数传递方式有( ),( )和( )。
13.根据优化所涉及的程序范围,可将优化分成为( ),( )和( )三个级别。
14.语法分析的方法大致可分为两类,一类是( )分析法,另一类是( )分析法。
15.预测分析程序是使用一张( )和一个( )进行联合控制的。
1. 一个上下文无关文法G包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组( )。
A. 字符串 B. 产生式 C. 开始符号 D. 文法
2.程序的基本块是指( )。
A. 一个子程序 B. 一个仅有一个入口和一个出口的语句
C. 一个没有嵌套的程序段 D. 一组顺序执行的程序段,仅有一个入口和一个出口
C. 该句子有两个不同的最右推导 D. 该句子有两棵不同的语法树
E. 该句子对应的语法树唯一
8. 下面( )语法制导翻译中,采用拉链—回填技术。
A.赋值语句B. 布尔表达式的计算 C. 条件语句 D. 循环语句
得分
三. 解答题(共60分)
1. (共15分)已知文法G[E]:
E→ETE|(E)|i
T→*|+
(1)将文法G改造成LL(1)文法;(5分)
(2)构造文法G中每个非终结符的FIRST集合及FOLLOW集合;(5分)
(3)构造LL(1)分析表。(5分)
2. (共12分)给定文法G[S]:S→S(S)|ε
(1) 给出句子(()())()()的规范推导过程;(4分)
(2) 指出每步推导所得句型的句柄;(4分)
31.2型文法又称为( )文法;3型文法又称为( )文法。
32.每条指令的执行代价定义为( )。
33.算符优先分析法每次都是对( )进行归约。
三、名词解释题:
1.局部优化
2.二义性文法
3.DISPLAY表
4.词法分析器
5.最左推导
6.语法
7.文法
8.基本块
9.语法制导翻译
10.短语
11.待用信息
12.规范句型
25.语法分析的方法大致可分为两类,一类是( )分析法,另一类是( )分析法。
26.对于文法G,仅含终结符号的句型称为 ( )。
27.所谓自上而下分析法是指( )。
28.语法分析器的输入是( ),其输出是( )。
29.局限于基本块范围的优化称( )。
30.预测分析程序是使用一张( )和一个( )进行联合控制的。
1. 设有文法G[I]:I→I1|I0|Ia|Ic|a|b|c
下列符号串中是该文法句子的有( )。
① ab0 ② a0c01 ③ aaa ④ bc10
可选项有:
A. ① B.②③④ C.③④ D.①②③④
2.程序的基本块是指( )。
A. 一个子程序 B. 一个仅有一个入口和一个出口的语句
C. 一个没有嵌套的程序段 D. 一组顺序执行的程序段,仅有一个入口和一个出口
(2)写出分析过程。(5分)
5. (共15分)设有表格构造文法G[S]:
S→a|∧|(T)
T→T,S|S
(1)计算文法G[S]的FIRSTVT集和LASTVT集。(5分)
(2)构造G[S]的优先关系表,并判断G[S]是否为算符优先文法。(5分)
(3)计算G[S]的优先函数。(5分)
得分
二. 单项选择题(每题2分,共10分)
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分)
A. 四元式序列 B. 间接三元式序列
C. 二元式序列 D. 机器语言程序或汇编语言程序
6. 一个文法所描述的语言是( );描述一个语言的文法是( )。
A. 唯一的 B. 不唯一的 C. 可能唯一,也可能不唯一
7. 如果在文法G中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。
A. 其最左推导和最右推导相同 B.该句子有两个不同的最左推导
13.扫描器
14.超前搜索
15.句柄
16.语法制导翻译
17.规范句型
18.素短语
19.语法
20.待用信息
21.语义
四、简答题:
1.写一个文法G, 使其语言为 不以0开头的偶数集。
2.已知文法G(S)及相应翻译方案
S→aAb {print “1”}
S→a {print “2”}
A→AS {print “3”}
Print A, B
end.
试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 A, B的值是什么?
5.文法G(S)
S→dAB
A→aA| a
B→Bb| ε
描述的语言是什么?
6.证明文法G(S)
S→SaS| ε
是二义性的。
7.已知文法G(S)
S→BA
A→c {print “4”}
输入acab, 输出是什么?
3. 已知文法G(S)
S→bAa
A→(B | a
B→Aa)
写出句子b(aa)b的规范归约过程。
4. 考虑下面的程序:

procedure p(x, y, z);
begin
y:=x+y;
z:=z*z;
end
begin
A:=2;
B:=A*2;
P(A, A, B);
operationnameabdominalpunctureoperationgastrointestinaldecompressiondigestivesystem填空题每空2分共20不同的编译程序关于数据空间的存储分配策略可能不同但大部分编译中采用的方案有两种
得分
一. 填空题(每空2分,共20分)
①提高编译程序的运行速度② 节省编译程序的存储空间
③提高目标程序的运行速度 ④ 为运行阶段的存储分配做准备
可选项有:
A.①② B. ②③ C. ③④ D. ④②
得分
2. (10分) 已知文法G[S]:
S→aBc|bAB
A→aAb|b
B→b|ε
(4)构造其LL(1)分析表;
(5)判断符号串baabbb是否为该文法的句子(写出含有符号栈、输入串和规则的分析过程)。
答案::
(1)栈式动态存储分配
(2)堆式动态存储分配
(3)左
(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,C
7.BCD,选对一个得1分且不超过满分,选错一个扣一分,扣完为止。
8.BCD,选对一个得1分且不超过满分,选错一个扣一分,扣完为止。
二、解答题
1.(1)文法存在左递归,消除左递归后的文法为:
E→(E)E’|i E’(2分)
E’→TEE’|ε(2分)
T→*|+(1分)
(2)(5分)没考虑#扣0.5分,其它错或少写一个扣0.5分
FIRST(E)={(,i} FIRST(E’)={*,+, ε} FIRST(T)={*,+}
22.如果一个文法存在某个句子对应两棵不同的语法树,则文法是二义性的。 ( )
二、填空题:
1.( )称为规范推导。
2.编译过程可分为 ( ) ,( ),( ),( )和( )五个阶段。
3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是( )。
4.从功能上说,程序语言的语句大体可分为( )语句和( )语句两大类。
3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于( )分析方法。
A. 自左向右 B. 自顶向下 C. 自底向上 D. 自右向左
4.在通常的语法分析方法中,( )特别适用于表达式的分析。
A. 算符优先分析法 B. LR分析法
C. 递归下降分析法 D. LL(1)分析法
相关文档
最新文档