编译原理习题及答案.pdfVIP

  • 1
  • 0
  • 约4.69千字
  • 约 8页
  • 2026-02-14 发布于河南
  • 举报

编译原理习题及答案

第一章

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。

6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中

间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意

义。因此选a。

7、b8、c9、d10、c

多选解答

1.b、c2.a、b、c、e

填空解答

是否生成目标程序2、词法分析中间代码生成3、源程序目标代

码生成

4、源程序目标语言

第二章

一、单项选择题

1、文法G:S→xSx|y所识别的语言是。

a.xyx

b.(xyx)*

c.xnyxn(n≥0)

d.x*yx*

2、文法G描述的语言L(G)是指。a.L(G)={α|S+?α,α∈VT*}

b.L(G)={α|S*?α,α∈VT*}c.L(G)={α|S*?α,α∈(VT∪VN*)}d.

L(G)={α|S+?α,α∈(VT∪VN*)}

3、有限状态自动机能识别。

a.上下文无关文法

b.上下文有关文法

c.正规文法

d.短语文法

4、设G为算符优先文法,G的任意终结符对a、b有以下关系成

立。

a.若f(a)g(b),则ab

b.若f(a)g(b),则abp=

c.a~b都不一定成立

d.a~b一定成立

5、如果文法G是无二义的,则它的任何句子α。

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

b.最左推导和最右推导对应的语法树可能不同

c.最左推导和最右推导必定相同

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

6、由文法的开始符经0步或多步推导产生的文法符号序列是。

文档评论(0)

1亿VIP精品文档

相关文档