编译原理习题

合集下载

编译原理习题

编译原理习题

编译原理习题⼀、填空题:1-01.编译程序的⼯作过程⼀般可以划分为词法分析,语法分析,语义分析,之间代码⽣成,代码优化等⼏个基本阶段,同时还会伴有表格处理和出错处理.1-02.若源程序是⽤⾼级语⾔编写的,⽬标程序是机器语⾔程序或汇编程序,则其翻译程序称为编译程序.1-03.编译⽅式与解释⽅式的根本区别在于是否⽣成⽬标代码.1-04.翻译程序是这样⼀种程序,它能够将⽤甲语⾔书写的程序转换成与其等价的⽤⼄语⾔书写的程序. 1-05.对编译程序⽽⾔,输⼊数据是源程序,输出结果是⽬标程序.1-06.如果编译程序⽣成的⽬标程序是机器代码程序,则源程序的执⾏分为两⼤阶段:编译阶段和运⾏阶段.如果编译程序⽣成的⽬标程序是汇编语⾔程序,则源程序的执⾏分为三个阶段:编译阶段,汇编阶段和运⾏阶段.1-07.若源程序是⽤⾼级语⾔编写的,⽬标程序是机器语⾔程序或汇编程序,则其翻译程序称为编译程序。

1-08.⼀个典型的编译程序中,不仅包括词法分析、语法分析、中间代码⽣成、代码优化、⽬标代码⽣成等五个部分,还应包括表格处理和出错处理。

其中,词法分析器⽤于识别单词。

1-09.编译⽅式与解释⽅式的根本区别为是否⽣成⽬标代码。

2-01.所谓最右推导是指:任何⼀步αβ都是对α中最右⾮终结符进⾏替换的。

2-02.⼀个上下⽂⽆关⽂法所含四个组成部分是⼀组终结符号、⼀组⾮终结符号、⼀个开始符号、⼀组产⽣式。

2-03.产⽣式是⽤于定义语法成分的⼀种书写规则。

2-04.设G[S]是给定⽂法,则由⽂法G所定义的语⾔L(G)可描述为:L(G)={x│S x,x∈V T*}。

2-05.设G是⼀个给定的⽂法,S是⽂法的开始符号,如果S x(其中x∈V*),则称x是⽂法的⼀个句型。

2-06.设G是⼀个给定的⽂法,S是⽂法的开始符号,如果S x(其中x∈V T*),则称x是⽂法的⼀个句⼦。

3-01.扫描器的任务是从源程序中识别出⼀个个单词符号。

4-01.语法分析最常⽤的两类⽅法是⾃上⽽下和⾃下⽽上分析法。

编译原理试题及答案

编译原理试题及答案

编译原理试题及答案一、选择题1. 编译器的主要功能是什么?A. 程序设计B. 程序翻译C. 程序调试D. 数据处理答案:B2. 下列哪一项不是编译器的前端处理过程?A. 词法分析B. 语法分析C. 语义分析D. 代码生成答案:D3. 在编译原理中,词法分析器的主要作用是什么?A. 识别程序中的关键字和标识符B. 将源代码转换为中间代码C. 检查程序的语法结构D. 确定程序的运行环境答案:A4. 语法分析通常采用哪种方法?A. 自顶向下分析B. 自底向上分析C. 正则表达式匹配D. 直接解释执行答案:B5. 语义分析的主要任务是什么?A. 检查程序的语法结构B. 检查程序的类型安全C. 识别程序中的变量和常量D. 将源代码转换为机器代码答案:B二、简答题1. 简述编译器的工作原理。

答案:编译器的工作原理主要包括以下几个步骤:词法分析、语法分析、语义分析、中间代码生成、代码优化和目标代码生成。

词法分析器将源代码分解成一系列的词素;语法分析器根据语法规则检查词素序列是否合法;语义分析器检查程序的语义正确性;中间代码生成器将源代码转换为中间代码;代码优化器对中间代码进行优化;最后,目标代码生成器将优化后的中间代码转换为目标机器代码。

2. 什么是词法分析器,它在编译过程中的作用是什么?答案:词法分析器是编译器前端的一个组成部分,负责将源代码分解成一个个的词素(tokens),如关键字、标识符、常量、运算符等。

它在编译过程中的作用是为语法分析器提供输入,是编译过程的基础。

三、论述题1. 论述编译器中的代码优化技术及其重要性。

答案:代码优化是编译过程中的一个重要环节,它旨在提高程序的执行效率,减少资源消耗。

常见的代码优化技术包括:常量折叠、死代码消除、公共子表达式消除、循环不变代码外提、数组边界检查消除等。

代码优化的重要性在于,它可以显著提高程序的运行速度和性能,同时降低程序对内存和处理器资源的需求。

四、计算题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、使用可以定义一个程序得意义。

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

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

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

2、编译过程通常可分为5个阶段,分别就是、语法分析、代码优化与目标代码生成。

3、编译程序工作过程中,第一段输入就是,最后阶段得输出为程序。

4、编译程序就是指将程序翻译成程序得程序。

单选解答1、将编译程序分成若干个“遍”就是为了使编译程序得结构更加清晰,故选b。

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

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

4、编译程序打交道最多得就就是各种表格,因此选d。

5、目标代码包括汇编指令代码、可重定位指令代码与绝对指令代码3种,因此不就是目标代码得只能选d。

编译原理习题(含历年专业考试题)

编译原理习题(含历年专业考试题)

1. LR 分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错 地点。 () 2. 构造 LR 分析器的任务就是产生 LR 分析表。 () 3 .LR 文法肯定是无二义的,一个无二义文法决不会是 LR 文法。 () 4. 在任何时候,分析栈的活前缀 X1X2...Xm 的有效项目集就是栈顶状态 Sm 所 在的那个 项目集。 () 5 .同心集的合并有可能产生新的“移进”/“归约”冲突。 () 6. 由于 LR(0) 分析表构造简单,所以它的描述能力强、适用面宽; LR(1) 分析 表因构造复杂而描述能力弱、适用面窄。 () 7 .所有 LR 分析器的总控程序都是一样的,只是分析表各有不同。 () 8. LR 分析技术无法适用二义文法。 () 9. 项目 A →β 1 ·β 2 对活前缀αβ 1 是有效的,其条件是存在规范推导 S'*= aAW= a β 1 β 2 ω。 () 10. SLR(1) 文法的特点是:当符号栈中的符号串为βα,而面临的输入符号为α 则存在 把α归约为 A 的规范句型的前缀β A α时,方可把 a 归约为 A 。 ( )
已知文法 G[S] : S → dAB A → aA|a B → Bb| ε (1) 试问 G[S] 是否为正规文法,为什么? (2) G[S] 所产生的语言是什么? (3) G[S] 能否改写为等价的正规文法 ?
答:(1)因为S → dAB不符合正规文法产生式A→aB或A→a, a∈VT* ,A,B∈VN的格式,故G[S]不是正规文法。 (2) G[S]产生的语言为: L={danbm|n≥1,m≥0} (3)可以得到G[S]对应的正规文法G’[S]: S→dA A→aA|aB|a B→bB|ε
编译原理
第一章---第六章补充
例1

编译原理习题及答案

编译原理习题及答案

( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( 10.× 22.√
) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) 11.
二、填空题: 2.编译过程可分为 ( 词法分析) , (语法分析) , (语义分析与中间代码生成 ) , (优化)和(目标 代码生成 )五个阶段。 3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是( 二义性的 4.从功能上说,程序语言的语句大体可分为( 5.语法分析器的输入是( 单词符号 6.扫描器的任务是从( 源程序中 执行性 )语句和(说明性 ) 。 ) 。 ) ,其输出是( 语法单位 )中识别出一个个( 单词符号 ) 。 )语句两大类。
因此,文法 G[为二义文法。
五.计算题(10 分) 已知文法 A->aAd|aAb| ε
判断该文法是否是 SLR(1) 文法,若是构造相应分析表,并对输入串 ab# 给出分析过程。 解:增加一个非终结符 S/后,产生原文法的增广文法有: S'->A A->aAd|aAb|ε 下 面 构 造 它 的 LR(0) 项 目 集 规 范 族 为 :
对输入串 ab#给出分析过程为:
一、是非题:
1.一个上下文无关文法的开始符,可以是终结符或非终结符。 2.一个句型的直接短语是唯一的。 3.已经证明文法的二义性是可判定的。 4.每个基本块可用一个 DAG 表示。 5.每个过程的活动记录的体积在编译时可静态确定。 6.2 型文法一定是 3 型文法。 7.一个句型一定句子。 8.算符优先分析法每次都是对句柄进行归约。 X 9.采用三元式实现三地址代码时,不利于对中间代码进行优化。 10.编译过程中,语法分析器的任务是分析单词是怎样构成的。 11.一个优先表一定存在相应的优先函数。 13.递归下降分析法是一种自下而上分析法。 14.并不是每个文法都能改写成 LL(1)文法。 15.每个基本块只有一个入口和一个出口。 16.一个 LL(1)文法一定是无二义的。 17.逆波兰法表示的表达试亦称前缀式。 18.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 19.正规文法产生的语言都可以用上下文无关文法来描述。 20.一个优先表一定存在相应的优先函数。 21.3 型文法一定是 2 型文法。 22.如果一个文法存在某个句子对应两棵不同的语法树, 则文法是二义性的。 答案:1.× 12.√ 13.× 2.× 14.√ 3.× 15.√ 4.√ 16.√ 5.√ 17.× 6.× × 18.√ 19.√ 20.× 21.√ 7.× 8.× 9.√ X 12.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。

编译原理习题

编译原理习题

22
20、3.3.4:用一个正规式描述select,注意:不关心大小写, 如SeleCt也可为本正规式匹配。
(s|S)(e|E)(l|L)(e|E)(c|C)(t|T)
21、练习4.5.2 文法SSS+|SS*|a,指出下面最右句型的句 柄 S 2)SS+a*a+ S S + S S * a
S
6、对_____表进行变动较为困难
A、三元式
B、间接三元式
C、四元式 D、三地址码
2
7、P202练习5.2.3.有产生式A→BCD,其中四个文法符号均 有两个属性,s为综合属性,i为继承属性。 判断是否符合S属性定义;是否符合L属性定义;是否存 在和这些规则一致的求值过程
1) A.s=B.i+C.s 2) A.s=B.i+C.s 和 D.i=A.i+B.s 3) A.s=B.s+D.s 4) A.s=D.i, B.i=A.s+C.s, C.i=B.s 和 D.i=B.i+C.i
一、实验目的
根据给出的文法编制语义分析程序。加深对自底向上 语义分析的理解。
二、实验时间
21学时
三、实验内容
对所给语言文法,增加相应的语义代码,并输出所得 三地址码;
实验报告必须包括采用的语法制导定义或翻译模式, 设计的思路,测试报告(输入测试例子,输出结果),设 计的体会。
28
实验三:语义分析实验
四、文法
<program> ::= <block> . <block> ::= <var-decl-list> <statement-list> <var-decl-list> ::= <var-decl> | <var-decl> <var-decl-list> <var-decl> ::= <type> <ident-list> ; <type> ::= float | int <ident-list> ::= id | <ident-list> , id

编译原理复习题

编译原理复习题

编译原理(一)一、是非题1、算符优先关系表不一定存在对应的优先函。

………………………………………()2、数组元素的地址计算与数组的存储方式有关。

……………………………()3、仅考虑一个基本块,不能确定一个赋值是否真是无用的。

…………………………()4、每个文法都能改写为LL(1)文法。

……………………………………………()5、对于数据空间的存贮分配,FORTRAN采用动态贮存分配策略。

………………()二、填空题1、从功能上说,程序语言的语句大体可分为()语句和()语句两大类。

2、扫描器的任务是从()中识别出一个个()。

3、所谓最右推导是指:()。

4、语法分析最常用的两类方法是()和()分析法。

5、一个上下文无关文法所含四个组成部分是()。

6、所谓语法制导翻译方法是()。

7、符号表中的信息栏中登记了每个名字的有关的性质,如()等等。

8、一个过程相应的DISPLA Y表的内容为()。

9、常用的两种动态存贮分配办法是()动态分配和()动态分配。

10、产生式是用于定义()的一种书写规则。

三、名词解释1、遍--2、无环路有向图(DAG)--3、语法分析--4、短语--5、后缀式--四、简述题1、考虑下面程序…………V ar a:integer;Procedure S(X);V ar X:integer;Begina:=a+1;X:=a+XEnd;Begina:=5;S(a);Print(a)End.试问:若参数传递方式分别采取传名和传值时,程序执行后输出a的值是什么?2、画出Pascal中实数(不带正负号,可带指数部分)的状态转换图。

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

4、已知文法G(S)S→a|∧|(T)T→T,S|S写出句子((a,a),a)的规范归约过程及每一步的句柄。

5、何谓优化?按所涉及的程序范围可分为哪几级优化?6、目标代码有哪几种形式?生成目标代码时通常应考虑哪几个问题?五、计算题1、写一个文法,使其语言是奇数集,且每个奇数不以0开头。

《编译原理》练习题

《编译原理》练习题

《编译原理》练习题一一、填空题(每空1分)1.设G [S ]是一个文法,我们把能由文法的 (1) 推导出来的符号串α称为G 的一个句型。

当句型α仅由 (2) 组成时 (即α∈V T *),则将它称为G 产生的句子。

2.从某一给定的状态q 出发,仅经过若干条 (3) 的矢线所能达到的状态所组成的集合称为ε-CLOSURE(q)。

3.设G=(V N ,V T ,P,S)是一文法,我们说G 中的一个符号X ∈V N ∪V T 是有用的,是指X 至少出现在 (4) 的推导过程中,否则,就说X 是无用的。

我们将不含形如A→A 的产生式和不含无用符号及无用产生式的文法称为 (5) 。

4.我们常采用形如 (class, value)的二元式作为一个单词的 (6) 。

其中,class 是一个整数,用来指示该单词的 (7) ,value 则是单词之值。

5.一个文法G[S]可表示成形如 (8) 的四元式。

其中V N ,V T ,P 均为非空的有限集,分别称为非终结符号集、终结符号集和产生式集, S ∈V N 为文法的开始符号。

此外,将出现在各产生式左部和右部的一切符号所组成的集合称为 (9) ,记作V 。

显然,V=V N ∪V T ,V N ∩V T =∅。

6.通常,可通过两种途径来构造词法分析程序。

其一是根据对语言中各类单词的某种描述或定义,用 (10) 构造词法分析程序;另外一种途径是所谓词法分析程序的(11) 。

7.设G 为一文法,A→α是G 的一个产生式,如果α具有υAδ的形式,其中υ,δ不同时为ε,则称产生式A→α是 (12) 。

若存在推导δυαA A *⇒⇒,则称产生式A→α是 (13) 。

8.设M=(K,Σ,f,S 0,Z)为一DFA ,并设s 和t 是M 的两个不同状态,我们说状态s,t 为某一输入串w (14) ,是指从s,t 中之一出发,当扫视完w 之后到达M 的终态,但从其中的另一个状态出发,当扫视完同一个w 后而进入 (15) 。

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

一、名词解释
1.正规文法
2. 编译程序
3. 文法的推导
4.子树
5. LL(1)文法
6. 文法的句子
7. LR (0)文法
8. 请写出四种参数传递的方式
二综合题
1. 请写出编译程序的五个步骤。

2. 给定文法G :(0)S →aAcBe (1)A →b
(2)A →Ab (3)B →d
若有句型 aAbcde ,试问b 是它的直接短语吗?它的短语是什么?句柄是什么?
3. 设有文法:S->aSbS|bSaS|ε
通过为句子abab 建立两个最左推导来说明该文法是二义文法。

4. 写出下列语言的上下文无关文法:{}0,|)(≥=m n G L c b a m n n
5. 写出下列语言的上下文无关文法:L(G)={a n b n c m d m
, n, m ≥0}。

6. 令文法G :S → aS
S →a | b
给出句子aaaab 的最左推导。

7. 证明下面的文法是有二义性的。

E →-EE
E →-E
E →a|b|c
8. 文法G 为: E→E+T|T
T→T*F|F
F→(E)|i
(1)画出句型(E+F)*i 的语法树;
(2)给出句型(E+F)*i 短语,简单(直接)短语,句柄。

9. 设字母表∑={a,b},给出∑上的正则式R=(a | ba )*
(1)构造NFA M ,使得L (M )=L (R )。

(2)将NFA M 确定化、最小化,得到minDFA M 。

(3)求右线形文法G ,使得L (G )=L (M ) 10. 设字母表∑={0,1},给出∑上的正则式R=0(0 | 1)*1
(1)构造NFA M ,使得L (M )=L (R )。

(2)将NFA M 确定化,最小化,得到minDFA M 。

11. 设字母表∑={0,1},给出∑上的正则式R=(a|b)*a (a|b)
(1)构造NFA M ,使得L (M )=L (R )。

(2)将NFA M确定化,得到DFA M。

12. 文法G:S →aABe
A → b | Abc
B → d
1)改写G为等价的LL(1)文法(消除左递归)。

2)求每个非终结符的FIRST集合和FOLLOW集合
3)构造预测分析表,即LL(1)分析表。

4)分析句子abbcde#的识别过程(25分)
13. 设文法G的产生式为:
S→aD
D→STe|ε
T→bH|H
H→d|ε
(1)求每个非终结符的First和follow集合;
(2)构造文法的LL(1)分析表;
(3)判定文法是否为LL(1)文法。

14. 对文法G[S]:
S→a| (T) |∧
T→T,S|S
(1) 消除文法左递归。

(2) 经改写后的文法是否是LL(1)的?给出它的预测分析表。

(3) 给出输入串(a,(a,a)#的分析过程,并说明该串是否为G的句子。

15.对文法G[S]:
S→a|(T)|∧
T→T,S|S
(1)计算该文法的Firstvt集合和Lastvt集合;
(2)计算该文法的优先关系。

该文法是一个算符优先文法吗?
(3)计算它的优先函数。

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

16. 给定文法G:(0)A→A∨B|B
(1)B→B∧C|C
(2)C→┐D|D
(3)D→(A)|i
(1)请问该文法是LL(1)文法吗?若是请分析句子i∨┐i的正确性;若不是请说明原因。

17.给定文法G:(0)S→SaF|F
(1)F→FbP|P
(2)P→c|d
(1)计算该文法的Firstvt集合和Lastvt集合;
(2)计算该文法的优先关系。

(3)计算它的优先函数。

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

18. 已知文法G:A→aAd|aAb|ε请构造该文法的SLR分析表,并分析输入串aabd#是否为该文法的合法句子
19. 已知拓广文法G:
(0)S→A
(1)A→Ab
(2)A→bB
(3)B→a
(1)写出该文法的LR(0)项目集规范族。

(2)构造该文法的SLR(1)分析表。

20. 设文法G为:S → A
A → BA | ε
B → aB | b
1)构造文法的LR(0)项目集规范族及相应的DFA。

(10分)
2)如果把每一个LR(0)项目看成一个状态,并从每一个形如B→α·Xβ的状态出发画一条标记为X的箭弧到状态B→αX·β,而且从每一个形如B→α·Aβ的状态出发画标记为ε的箭弧到所有形如A→·γ的状态。

这样就得到了一个NFA。

说明这个NFA与(1)中的DFA是等价的。

3) 构造它的LR(1)分析表。

4)给出输入符号串abab# 的LR(1)分析过程。

21. 考虑文法:
T →T(T)
T →ε
1)构造文法的LR(0)项目集规范族及相应的DFA。

2)如果把每一个LR(0)项目看成一个状态,并从每一个形如B →α·Xβ的状态出发画一条标记为X的箭弧到状态B →αX·β,而且从每一个形如B →α·Aβ的状态出发画标记为ε的箭弧到所有形如A →·γ的状态。

这样就得到了一个NFA。

说明这个NFA与(a)中的DFA是等价的。

3)构造文法的SLR分析表。

4)构造文法的LR(1)分析表和LALR分析表。

5)对于输入串(()),给出LR(1)分析器所作出的动作。

22. 将下面的句子翻译成四元式。

while A<C∧B<D do if A==1 then C:=C+1 else C:=C*D;
23. 将下面的句子翻译成四元式。

while C>0 do if A B then C:=C+D else C:=C*D;
24. 设数组A的说明语句是array[-4:5,-3:3],假定数组按行存放,存储器按字节编址,每6个字节为一机器字,令数组的首地址为1000,问
(1)A[I,J]和A[I+1,J+1]的地址是什么?
(2)按上题对循环语句的翻译结构,翻译下列语句
for i:=-4 to 5 do
for j:=-3 to 3 do
A[i,j]:=0
成四元式序列。

相关文档
最新文档