编译原理模拟试题六

合集下载

编译原理题库

编译原理题库

编译原理题库
1. 什么是编译原理?
编译原理是研究将高级程序语言翻译成为机器语言的原理和方法的学科。

2. 编译器的主要功能是什么?
编译器的主要功能包括词法分析、语法分析、语义分析、中间代码生成、代码优化和目标代码生成等。

3. 什么是词法分析?
词法分析是将输入的字符流转化为标记流的过程。

4. 什么是语法分析?
语法分析是将词法分析得到的标记流转化为语法树的过程。

5. 什么是语义分析?
语义分析是对语法树进行解析,检查程序中是否存在语义错误或不符合语言规范的地方。

6. 什么是中间代码生成?
中间代码生成是将语义分析得到的语法树转化为中间表示形式,以便进行后续的代码优化和目标代码生成。

7. 什么是代码优化?
代码优化是对中间代码进行优化,以提高程序的执行效率和空间利用率。

8. 什么是目标代码生成?
目标代码生成是将优化后的中间代码转化为机器语言的过程。

9. 什么是语法制导翻译?
语法制导翻译是一种以语法规则为基础,通过对语法树的遍历和语义规则的应用来进行翻译的方法。

10. 什么是LL(1)文法?
LL(1)文法是一种上下文无关文法,它具有左递归和左因子的特点,并且在进行预测分析时每个非终结符的每个可能产生式都有唯一的选择。

编译原理练习题

编译原理练习题

编译原理练习题一、选择题(每题2分,共10分)1. 编译器的主要功能是将源代码转换为:A. 可执行文件B. 汇编代码C. 机器代码D. 中间代码2. 词法分析阶段的主要任务是:A. 将源代码分解成多个语句B. 将源代码分解成多个单词C. 将源代码分解成多个符号D. 将源代码分解成多个表达式3. 下列哪个是自顶向下的语法分析方法?A. LL(1)分析B. LR分析C. LALR分析D. GLR分析4. 语义分析的主要任务是:A. 检查语法正确性B. 检查类型正确性C. 检查代码风格D. 检查代码的可读性5. 编译过程中的优化主要发生在:A. 词法分析阶段B. 语法分析阶段C. 语义分析阶段D. 代码生成阶段二、填空题(每空1分,共10分)6. 编译器的前端主要包括词法分析、语法分析、________和________四个阶段。

7. 编译器的后端主要包括代码生成、________和________两个阶段。

8. 编译原理中的“三地址代码”是指每个指令最多有三个________。

9. 编译过程中的“死代码”是指________。

10. 编译器的优化技术可以分为________优化和________优化。

三、计算题(每题5分,共10分)11. 假设有一个简单的算术表达式:a * b + c * d。

请使用三地址代码表示这个表达式,并给出相应的指令序列。

四、简答题(每题5分,共10分)12. 简述编译原理中词法分析器的作用和实现方法。

五、论述题(每题15分,共15分)13. 论述编译原理中语法分析的两种主要方法:自顶向下分析和自底向上分析,并比较它们的优缺点。

编译原理》模拟期末试题汇总6套含答案

编译原理》模拟期末试题汇总6套含答案

《编译原理》模拟试题一一、是非题(请在括号内,正确的划√,错误的划×)(每个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.简单优先文法同意随意两个产生式拥有同样右部。

(×)二、选择题(请在前括号内选择最切实的一项作为答案划一个勾,多划按错论)(每4分,共40分)1.一个编译程序中,不单包含词法剖析,_____,中间代码生成,代码优化,目标代码生成等五个部分。

A.() 语法剖析B.()文法剖析C.()语言剖析D.()解说剖析2.词法剖析器用于辨别A.()字符串C.()单词_____。

B.()D.()语句表记符3.语法剖析器则能够发现源程序中的_____。

A.() C.()语义错误错误并校订B.()D.()语法和语义错误语法错误4.下边对于解说程序的描绘正确的选项是_____。

解说程序的特色是办理程序时不产生目标代码解说程序合用于COBOL和FORTRAN语言解说程序是为翻开编译程序技术的僵局而开发的A.()(1)(2) B.()(1) C.()(1)(2)(3) D.()(2)(3) 5.解说程序办理语言时, 大部分采纳的是_____方法。

A.()源程序命令被逐一直接解说履行B.() C.()先将源程序转变为中间代码先将源程序解说转变为目标程序,再解说履行, 再履行D.()以上方法都能够6.编译过程中,语法剖析器的任务就是_____。

编译原理考试题

编译原理考试题

编译原理考试题
1. 编译器的作用是什么?简述编译器的基本工作流程。

2. 解释什么是词法分析。

描述词法分析器的基本工作原理。

3. 什么是语法分析?描述语法分析器的基本工作原理。

4. 解释语义分析的概念。

语义分析器的基本工作原理是什么?
5. 请简要解释编译器的前端和后端分别是做什么的。

6. 什么是中间代码?为什么编译器要生成中间代码?
7. 解释什么是符号表。

符号表在编译过程中起到什么作用?
8. 简述优化在编译过程中的作用。

列举并解释两种常见的优化技术。

9. 解释静态链接和动态链接的区别。

10. 请解释解释器和编译器之间的区别。

描述它们各自的工作
原理。

11. 解释冲突解析算法中的"移进-归约"冲突和"归约-归约"冲突。

12. 简述LL(1)文法和LR(1)文法的特点及区别。

13. 解释编程语言中的数据类型检查和类型推导的概念。

14. 简要描述语法制导翻译的概念和基本原理。

15. 请解释正则表达式和有限自动机之间的关系。

注意:以上为编译原理考试相关的问题,文中不含有标题相同的文字。

编译原理试题及答案

编译原理试题及答案

《编译原理》模拟题一.单选题1.()是两类程序语言处理程序.A.高级语言程序和低级语言程序B.解释程序和编译程序C.编译程序和操作系统D.系统程序和应用程序[答案]:B2.解释程序处理语言时,大多数采用的是()方法.A.源程序命令被逐个直接解释执行B.先将源程序转化为中间代码,再解释执行C.先将源程序解释转化为目标程序,再执行D.以上方法都可以[答案]:A3.()是一种典型的解释型语言.A.BASICB.CC.FORTRAND.PASCAL[答案]:A4.与编译系统相比,解释系统().A.比较简单,可移植性好,执行速度快B.比较复杂,可移植性好,执行速度快C.比较简单,可移植性差,执行速度慢D.比较简单,可移植性好,执行速度慢[答案]:D5.编译程序是一种().A.汇编程序B.翻译程序C.解释程序D.目标程序[答案]:B6.编译程序是对().A.汇编程序的翻译B.高级语言程序的解释执行C.机器语言的执行D.高级语言的翻译[答案]:D7.用高级语言编写的程序经编译后产生的程序叫().A.源程序B.目标程序C.连接程序D.解释程序[答案]:B8.将编译程序分成若干个“遍”是为了().A.提高程序的执行效率B.使程序的结构更加清晰C.利用有限的机器内存并提高机器的执行效率D.利用有限的机器内存但降低了机器的执行效率[答案]:B9.构造编译程序应掌握().A.源程序B.目标语言C.编译方法D.以上三项都是[答案]:D10.通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括().A.模拟执行器B.解释器C.表格处理和出错处理D.符号执行器[答案]:C11.编译程序绝大多数时间花在()上.A.出错处理B.词法分析C.目标代码生成D.管理表格[答案]:D12.程序的基本块是指().A.一个子程序B.一个仅有一个入口和一个出口的语句C.一个没有嵌套的程序段D.一组顺序执行的程序段,仅有一个入口和一个出口[答案]:D13.变量应当().B.持有右值C.既持有左值又持有右值D.既不持有左值也不持有右值[答案]:C14.数组的内情向量中肯定不含有数组的()的信息.A.维数B.类型C.维上下界D.各维的界差[答案]:A15.一个上下文无关文法G包括四个组成部分:一组终结符,一组非终结符,一个开始符号,以及一组().A.字符串B.产生式C.非开始符号D.文法[答案]:B16.一个文法所描述的语言是().A.唯一的B.不唯一的C.可能唯一,也可能不唯一D.都不对[答案]:A17.文法G产生的()的全体是该文法描述的语言.A.句型B.终结符集C.非终结符集D.句子[答案]:D18.若文法G定义的语言是无限集,则文法必然是().A.递归的B.前后文无关的C.二义性的D.无二义性的[答案]:A19.文法分为四种类型,即0型,1型,2型,3型.其中2型文法是().A.短语文法C.上下文有关文法D.上下文无关文法[答案]:C20.四种形式语言文法中,1型文法又称为()文法.A.短语文法B.正则文法C.上下文有关文法D.上下文无关文法[答案]:D21.正规式M1和M2等价是指().A.M1和M2的状态数相等B.Ml和M2的有向弧条数相等C.M1和M2所识别的语言集相等D.Ml和M2状态数和有向弧条数相等[答案]:C22.词法分析器的输出结果是().A.单词的种别编码B.单词在符号表中的位置C.单词的种别编码和自身值D.单词自身值[答案]:C23.词法分析器用于识别().A.字符串B.语句C.单词D.标识符[答案]:C24.扫描器所完成的任务是从字符串形式的源程序中识别出一个个具有独立含义的最小语法单位即().A.字符B.单词C.句子D.句型[答案]:B25.一个句型中称为句柄的是该句型的最左().A.非终结符号B.短语D.直接短语[答案]:D26.下推自动机识别的语言是().A.0型语言B.1型语言C.2型语言D.3型语言[答案]:C27.如果文法G是无二义的,则它的任何句子α().A.最左推导和最右推导对应的语法树必定相同B.最左推导和最右推导对应的语法树可能不同C.最左推导和最右推导必定相同D.可能存在两个不同的最左推导,但它们对应的语法树相同[答案]:A28.采用自上而下分析,必须().A.消除左递归B.消除右递归C.消除回溯D.提取公共左因子[答案]:C29.在规范归约中,用()来刻画可归约串.A.直接短语B.句柄C.最左素短语D.素短语[答案]:B30.若a为终结符,则A->α·aβ为()项目.A.归约B.移进C.接受D.待约[答案]:B31.高级语言编译程序常用的语法分析方法中,递归下降分析法属于()分析方法.A.自左向右B.自顶向下C.自底向上D.自右向左32.在通常的语法分析方法中,()特别适用于表达式的分析.A.算符优先分析法B.LR分析法C.递归下降分析法D.LL(1)分析法[答案]:A33.语法分析器则可以发现源程序中的().A.语义错误B.语法和语义错误C.错误并校正D.语法错误[答案]:D34.后缀式ab+cd+/可用表达式()来表示.A.a+b/c+dB.(a+b)/(c+d)C.a+b/(c+d)D.a+b+c/d[答案]:B35.中间代码生成时所依据的是().A.语法规则B.词法规则C.语义规则D.等价变换规则[答案]:C36.()和代码优化部分不是每个编译程序都必需的.A.语法分析B.中间代码生成C.词法分析D.目标代码生成[答案]:B37.常用的中间代码形式不含().A.三元式B.四元式C.逆波兰式D.语法树[答案]:D38.代码优化的目的是().A.节省时间B.节省空间C.节省时间和空间把编译程序进行等价交换[答案]:C39.优化可生成()的目标代码.A.运行时间较短B.占用存储空间较小C.运行时间短但占用内存空间大D.运行时间短且占用存储空间小[答案]:D40.下列()优化方法不是针对循环优化进行的.A.强度削弱B.删除归纳变量C.删除多余运算D.代码外提[答案]:C41.基本块内的优化为().A.代码外提,删除归纳变量B.删除多余运算,删除无用赋值C.强度削弱,代码外提D.循环展开,循环合并[答案]:B42.代码生成阶段的主要任务是().A.把高级语言翻译成汇编语言B.把高级语言翻译成机器语言C.把中间代码变换成依赖具体机器的目标代码D.把汇编语言翻译成机器语言[答案]:C43.在目标代码生成阶段,符号表用于().A.目标代码生成B.语义检查C.语法检查D.地址分配[答案]:D44.程序所需的数据空间在程序运行前就可确定,称为()管理技术.A.动态存储B.栈式存储C.静态存储D.堆式存储[答案]:C45.堆式动态分配申请和释放存储空间遵守()原则.A.先请先放B.先请后放C.后请先放D.任意[答案]:D46.编译程序使用()区别标识符的作用域.A.说明标识符的过程或函数名B.说明标识符的过程或函数的静态层次C.说明标识符的过程或函数的动态层次D.标识符的行号[答案]:B47.生成能被5整除的正整数的文法G[Z]是().A.G(Z):Z→AC,A→BA|B,B→0|1|2|…|9,C→0|5B.G(Z):Z→AC,A→BA|ε,B→0|1|2|…|9,C→0|5C.G(Z):Z→AC|5,A→BA|B,B→0|1|2|…|9,C→0|5D.G(Z):Z→AC|C,A→BA|B,B→0|1|2|…|9,C→0|5[答案]:C48.符号串ab1b2是给定文法G[A]:A→aB,B→bB|b的句子,该句子的句柄是().A.b1B.b2C.cD..b1b2[答案]:B49.一般程序设计语言的定义都涉及()三个方面.①语法②语义③语用④程序基本符号的确定A.①,②和③B.①,②和④C.①,③和④D.②,③和④[答案]:B50.下述语句类中,()在编译阶段通常不产生可执行代码.A.赋值语句B.流程控制语句C.说明语句D.输入输出语句[答案]:C51.算符文法是指()的文法.①没有形如U→...VW...的规则(U,V,W错误!未找到引用源。

编译原理编译原理考试卷模拟考试题.docx

编译原理编译原理考试卷模拟考试题.docx

《编译原理》考试时间:120分钟 考试总分:100分遵守考场纪律,维护知识尊严,杜绝违纪行为,确保考试结果公正。

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、正规式MI和M2等价是指()()A.MI和M2的状态数相等B.Ml和M2的有向弧条数相等。

C.M1和M2所识别的语言集相等D.Ml和M2状态数和有向弧条数相等7、中间代码生成时所依据的是()()A.语法规则B.词法规则C.语义规则D.等价变换规则8、后缀式ab+cd+/可用表达式()来表示。

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

()A.动态存储B.栈式存储C.静态存储D.堆式存储10、堆式动态分配申请和释放存储空间遵守()原则。

()A.先请先放B.先请后放C.后请先放D.任意11、一个编译程序中,不仅包含词法分析,(),中间代码生成,代码优化,目标代码生成等五个部分。

编译原理考试试题

编译原理考试试题

编译原理考试试题一、单项选择题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.对源代码进行优化,使其更加易于阅读和理解二、多项选择题1、编译原理中的“编译器”包括以下哪些部分?()A.词法分析器B.语法分析器C.语义分析器D.优化器E.目标代码生成器2、编译原理中的“中间代码”可以是以下哪些形式?()A.三码B.汇编语言C.目标代码D.机器码E.以上都不是3、编译原理中的“优化”包括以下哪些方面?()A.局部优化B.全局优化C.中间代码优化D.机器码优化E.以上都是4、下列哪些问题是编译原理所要解决的问题?()A.词法分析中的单词识别B.语法分析中的语法错误检查C.语义分析中的类型检查D.优化中的程序运行速度优化E.以上都是船舶原理考试试题一、选择题(每题2分,共20分)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.船舶横移速度与船长的比值二、简答题(每题10分,共30分)1、请简述船舶推进器选择的原则和依据。

编译原理试题及答案

编译原理试题及答案

编译原理试题及答案一、选择题1. 编译器的主要功能是什么?A. 将高级语言代码翻译成机器语言代码B. 进行程序调试C. 进行代码优化D. 管理程序运行时的内存分配答案:A2. 词法分析器的主要任务是什么?A. 将源代码分解成多个语句B. 将源代码分解成多个词素C. 检查源代码的语法正确性D. 将词素转换为相应的语法单位答案:B3. 下列哪个是自顶向下的语法分析方法?A. LL(1)分析法B. LR(1)分析法C. LALR(1)分析法D. GLR分析法答案:A4. 语义分析的主要任务是什么?A. 检查程序的语法正确性B. 检查程序的类型正确性C. 将源代码转换为目标代码D. 进行程序的优化答案:B5. 代码生成阶段的主要任务是什么?A. 将语法树转换为目标代码B. 进行程序的优化C. 检查程序的类型正确性D. 将源代码分解成多个词素答案:A二、简答题1. 简述编译过程的主要阶段。

答案:编译过程主要分为四个阶段:词法分析、语法分析、语义分析和代码生成。

词法分析将源代码分解成词素,语法分析检查源代码的语法结构,语义分析检查源代码的语义正确性,代码生成将源代码转换为目标代码。

2. 什么是中间代码?它在编译过程中起到什么作用?答案:中间代码是一种介于源代码和目标代码之间的代码形式,它通常具有更接近于机器语言的特性,但仍然保持一定的抽象级别。

中间代码在编译过程中起到桥梁的作用,它使得代码优化和目标代码生成更加方便和高效。

三、论述题1. 论述编译器优化的几种常见方法。

答案:编译器优化主要包括以下几种方法:常量折叠、死代码消除、公共子表达式消除、循环优化、代码内联、寄存器分配等。

这些优化方法可以提高程序的执行效率,减少资源消耗,提高程序的运行速度。

结束语:本试题涵盖了编译原理的基本知识点,包括编译器的功能、编译过程的主要阶段、中间代码的作用以及编译器优化的方法。

希望考生能够通过本试题加深对编译原理的理解和掌握。

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

《编译原理》模拟试题六一、是非题(请在括号内,正确的划√,错误的划×)(每个2分,共20分)1.设r和s分别是正规式,则有L(r|s)=L(r)L(s)。

(×)2.确定的自动机以及不确定的自动机都能正确地识别正规集。

(√)3.词法分析作为单独的一遍来处理较好。

(× )4.构造LR分析器的任务就是产生LR分析表。

(√)5.规范归约和规范推导是互逆的两个过程。

(× )6.同心集的合并有可能产生新的“移进”/“归约”冲突。

(× )7.LR分析技术无法适用二义文法。

(× )8.树形表示和四元式不便于优化,而三元式和间接三元式则便于优化。

(×)9.程序中的表达式语句在语义翻译时不需要回填技术。

(√)10.对中间代码的优化依赖于具体的计算机。

(× )二、选择题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)(每个4分,共40分)1.编译程序绝大多数时间花在_____ 上。

A.( ) 出错处理 B.( ) 词法分析C.( ) 目标代码生成D.( ) 表格管理2.编译程序是对_____。

A.( ) 汇编程序的翻译 B.( ) 高级语言程序的解释执行C.( ) 机器语言的执行D.( ) 高级语言的翻译3.采用自上而下分析,必须_____。

A.( ) 消除左递归 B.( ) 消除右递归C.( ) 消除回溯 D.( ) 提取公共左因子4.在规范归约中,用_____来刻画可归约串。

A.( )直接短语B.( )句柄C.( )最左素短语D.( )素短语5.若a为终结符,则A->α ·aβ为_____项目。

A.( )归约B.( ) 移进C.( ) 接受D.( ) 待约6.间接三元式表示法的优点为_____。

A.( ) 采用间接码表,便于优化处理B.( ) 节省存储空间,不便于表的修改C.( ) 便于优化处理,节省存储空间 D.( ) 节省存储空间,不便于优化处理7.基本块内的优化为_____。

A. ( ) 代码外提,删除归纳变量B.( ) 删除多余运算,删除无用赋值C.( ) 强度削弱,代码外提 D.( ) 循环展开,循环合并8. 在目标代码生成阶段,符号表用_____。

A.( ) 目标代码生成B.( ) 语义检查C.( ) 语法检查D.( ) 地址分配9.若项目集Ik含有A->α·,则在状态k时,仅当面临的输入符号a∈FOLLOW(A)时,才采取“A->α ·”动作的一定是_____。

A. ( ) LALR文法 B.( ) LR(0)文法C.( ) LR(1)文法D.( ) SLR(1)文法10.堆式动态分配申请和释放存储空间遵守_____原则。

A. ( ) 先请先放 B.( ) 先请后放C.( ) 后请先放 D. ( ) 任意三、填空题(每空1分,共10分)1.词法分析基于__正则___文法进行,即识别的单词是该类文法的句子。

2.语法分析基于__上下文无关___文法进行,即识别的是该类文法的句子。

语法分析的有效工具是__语法树___。

3.分析句型时,应用算符优先分析技术时,每步被直接归约的是__最左素短语___,而应用LR分析技术时,每步被直接归约的是___句柄__。

4.语义分析阶段所生成的与源程序等价的中间表示形式可以有__逆波兰___、___四无式表示__与___三元式表示__等。

5.按Chomsky分类法,文法按照___规则定义的形式__进行分类。

6.一个文法能用有穷多个规则描述无穷的符号串集合(语言)是因为文法中存在有___递归__定义的规则。

四、简答题(20分)1. 文法 G[S] 为:S->Ac|aBA->abB->bc写出 L(G[S]) 的全部元素。

解:S=>Ac=>abc或S=>aB=>abc所以L(G[S])={abc}2. 构造正规式 1(0|1)*101 相应的DFA。

解:先构造NFA:确定化:重新命名,令AB为B、AC为C、ABY为D得:所以,可得DFA为:3. 文法S->a|^|(T)T->T,S|S对 (a,(a,a) 和 (((a,a),^,(a)),a) 的最左推导。

解:对(a,(a,a)的最左推导为:S=>(T) =>(T,S) =>(S,S) =>(a,S)=>(a,(T)) =>(a,(T,S)) =>(a,(S,S))=>(a,(a,S)) =>(a,(a,a))对(((a,a),^,(a)),a) 的最左推导为:S=>(T) =>(T,S) =>(S,S) =>((T),S)=>((T,S),S) =>((T,S,S),S) =>((S,S,S),S)=>(((T),S,S),S) =>(((T,S),S,S),S) =>(((S,S),S,S),S)=>(((a,S),S,S),S) =>(((a,a),S,S),S) =>(((a,a),^,S),S)=>(((a,a),^,(T)),S) =>(((a,a),^,(S)),S) =>(((a,a),^,(a)),S) =>(((a,a),^,(a)),a)4. 文法:S->MH|aH->LSo| εK->dML| εL->eHfM->K|bLM判断 G 是否为 LL(1) 文法,如果是,构造 LL(1) 分析表。

解:各符号的FIRST集和FOLLOW集为:预测分析表为:由于预测分析表中无多重入口,所以可判定文法是LL(1)的。

五.计算题(10分)已知文法 G[S] 为:S->a|^|(T)T-> T,S|S(1) 计算 G[S] 的 FIRSTVT 和 LASTVT 。

(2) 构造 G[S] 的算符优先关系表并说明 G[S] 是否未算符优先文法。

(3) 计算 G[S] 的优先函数。

(4) 给出输入串 (a,a)# 的算符优先分析过程。

解:(1)各符号的FIRSTVT和LASTVT:(2)算符优先关系表:(3)对应的算符优先函数为:(4)句子(a,a)#分析过程如下:一、选择题(每个选择题 2 分,共 20 分)1 .文法 G 产生的⑴ 的全体是该文法描述的语言。

A .句型 B. 终结符集 C. 非终结符集 D. 句子2 .若文法 G 定义的语言是无限集,则文法必然是⑵ :A .递归的B 前后文无关的C 二义性的D 无二义性的3 . Chomsky 定义的四种形式语言文法中, 0 型文法又称为⑶ 文法; 1 型文法又称为⑷ 文法; 2 型语言可由⑸ 识别。

A .短语结构文法B 前后文无关文法C 前后文有关文法D 正规文法E 图灵机F 有限自动机G 下推自动机4 .一个文法所描述的语言是⑹ ;描述一个语言的文法是⑺ 。

A .唯一的B 不唯一的C 可能唯一,好可能不唯一5 .数组的内情向量中肯定不含有数组的⑻ 的信息A.维数 B.类型 C.维上下界 D.各维的界差6 .在下述的编译方法中,自底向上的方法有⑼ ,自顶向下的分析方法有⑽ 。

①简单优先分析②算符优先分析③递归下降分析④预测分析技术⑤LR (K)分析⑥ SLR(k)分析⑦ LL(k)分析⑧LALR(K)分析A.③④⑦B. ③④⑧C.①②⑧D.③④⑤⑥⑦E.①②⑤⑥⑦F. ①②⑤⑥⑧二、简答题(每小题 5 分,共 20 分)1 . LL ( 1 )分析法对文法有哪些要求2 .常见的存储分配策略有几种它们都适合于什么性质的语言3 .常见循环优化都有哪些项目4 .什么是活动记录它主要由哪些内容构成三、( 8 分)化简文法 G[S] :S → ASe | BCaD | aD | ACA → Cb | DBSC → bC | dB → AcD → aD四、( 12 分)设L í {a,b,c}* 是满足下述条件的符号串构成的语言:(1)若出现 a ,则其后至少紧跟两个 c ;(2)若出现 b ,其后至少紧跟一个 c 。

试构造识别 L 的最小化的 DFA ,并给出描述 L 的正规表达式。

五、( 12 分)已给文法 G[S] :S → SaP | Sf | P P → qbP | q 将 G[S] 改造成 LL ( 1 )文法,并给出 LL ( 1 )分析表。

六、( 12 分)给定文法 G[S] :S → Aa|dAb|Bb|dBa A → c B → c 构造文法 G[S] 的 LR ( 1 )分析表。

七、( 8 分)将下面的条件语句表示成逆波兰式和四元式序列:if a>b then x:=a+b*c else x:=b-a;八、( 8 分)给定基本块:A:=3*5B:=E+FC:=A+12D:=E+FA:=D+12C:=C+1E:=E+F假定出基本块后,只有 A 、 C 、 E 是活跃的,给出用 DAG 图完成优化后的代码序列。

参考答案:一、⑴ D ⑵ A ⑶ A ⑷ C ⑸ G. ⑹ A ⑺ B ⑻ A ⑼ F ⑽ A二、 1 .对于 G 中的每个产生式 A →γ 1 | γ 2 | … | γ m ,其各候选式均应满足:(1)不同的候选式不能推出以同一终结符号打头的符号串,即FIRST( γ i ) ∩ FIRST( γ j )= φ( 1 ≤ i ,j ≤ m ;i ≠ j )(2)若有γ j ε,则其余候选式γ i 所能推出的符号串不能以 FOLLOW(A) 中的终结符号开始,即有FIRST( γ i ) ∩ FOLLOW(A)= φ(i ≤ 1,2, … ,m ;i ≠ j )2 .有三种分配存储空间的方式:( 1 )静态分配若在编译阶段就能确定源程序中各个数据实体的存储空间大小,则可以采用较简单的静态存储管理。

适合静态管理的语言应具备条件:数组上下界是常数、过程调用不允许递归、不允许动态建立数据实体。

( 2)栈式分配适用于允许递归调用的程序设计语言;(3 )堆式分配对于允许程序在运行时为变量动态申请和释放存储空间的语言,采用堆式分配是最有效的解决方案。

3 .不变运算外提;运算强度削弱;消除归纳变量;下标变量地址计算优化。

4 .一个过程的一次执行所需信息的管理,是通过称为活动记录的连续存储块来实现的。

活动记录的主要内容有:( 1)临时变量域存放目标程序临时变量的值;( 2 )局部数据域存放过程本次执行时的局部数据、简单变量及数组内情向量等;( 3 )机器状态域保存在调用过程前有关机器状态的信息,包括各寄存器的当前值及返回地址等;( 4 )存取链为访问其它活动记录中所存放的非局部数据所提供的链地址;(5 )控制链指向主调过程的活动记录;(6 )实参存放主调过程为被调用过程所提供的实参信息;( 6 )返回值为主调过程存放被调过程的返回值三、化简后:S → ASe|AC A → Cb C → bC | d四、 DFA 如图所示。

相关文档
最新文档