《编译原理》课程复习资料
一、判断题:
1.一个上下文无关文法的开始符,可以是终结符或非终结符。 [ ]
2.一个句型的直接短语是唯一的。 [ ]
3.已经证明文法的二义性是可判定的。 [ ]
4.每个基本块可用一个DAG表示。 [ ]
5.每个过程的活动记录的体积在编译时可静态确定。 [ ]
6.2型文法一定是3 型文法。 [ ]
7.一个句型一定句子。 [ ]
8.算符优先分析法每次都是对句柄进行归约。 [ ]
9.采用三元式实现三地址代码时,不利于对中间代码进行优化。 [ ]
10.编译过程中,语法分析器的任务是分析单词是怎样构成的。 [ ]
11.一个优先表一定存在相应的优先函数。 [ ]
12.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 [ ]
13.递归下降分析法是一种自下而上分析法。 [ ]
14.并不是每个文法都能改写成 LL(1)文法。 [ ]
15.每个基本块只有一个入口和一个出口。 [ ]
16.一个 LL(1)文法一定是无二义的。 [ ]
17.逆波兰法表示的表达试亦称前缀式。 [ ]
18.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 [ ]
19.正规文法产生的语言都可以用上下文无关文法来描述。 [ ]
20.一个优先表一定存在相应的优先函数。 [ ]
21.3型文法一定是2 型文法。 [ ]
22.如果一个文法存在某个句子对应两棵不同的语法树,则文法是二义性的。 [ ]
二、填空题:
1. 称为规范推导。
2.编译过程可分为 , , , 和 五个阶段。
3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是 。
4.从功能上说,程序语言的语句大体可分为 语句和 语句两大类。
5.语法分析器的输入是 ,其输出是 。
6.扫描器的任务是从 中识别出一个个 。
7.符号表中的信息栏中登记了每个名字的有关的性质,如 等等。
8.一个过程相应的DISPLAY表的内容为 。
9.一个句型的最左直接短语称为句型的 。
10.常用的两种动态存贮分配办法是 动态分配和 动态分配。
11.一个名字的属性包括 和 。
12.常用的参数传递方式有 , 和 。
13.根据优化所涉及的程序范围,可将优化分成为 , 和 三个级别。
14.语法分析的方法大致可分为两类,一类是 分析法,另一类是 分析法。
15.预测分析程序是使用一张 和一个 进行联合控制的。
16.常用的参数传递方式有 , 和 。
17.一张转换图只包含有限个状态,其中有一个被认为是 态;而且实际上至少要有一个 态。
18.根据优化所涉及的程序范围,可将优化分成为 , 和 三个级别。
19.语法分析是依据语言的 规则进行。中间代码产生是依据语言的 规则进行的。
20.一个句型的最左直接短语称为句型的 。
21.一个文法G,若它的预测分析表M不含多重定义,则该文法是 文法。
22.对于数据空间的存贮分配, FORTRAN采用 策略, PASCAL采用 策略。
23.如果一个文法存在某个句子对应两棵不同的语法树, 则称这个文法是 。
24.最右推导亦称为 ,由此得到的句型称为 句型。
25.语法分析的方法大致可分为两类,一类是 分析法,另一类是 分析法。
26.对于文法G,仅含终结符号的句型称为 。
27.所谓自上而下分析法是指 。
28.语法分析器的输入是 ,其输出是 。
29.局限于基本块范围的优化称 。
30.预测分析程序是使用一张 和一个 进行联合控制的。
31.2型文法又称为 文法;3型文法又称为 文法。
32.每条指令的执行代价定义为 。
33.算符优先分析法每次都是对 进行归约。
三、名词解释:
1.局部优化
2.二义性文法
3.DISPLAY表
4.词法分析器
5.最左推导
6.语法
7.文法
8.基本块
9.语法制导翻译
10.短语
11.待用信息
12.规范句型
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”}
A→AS {print “3”}
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);
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→BS| d
B→aA| bS | c
的预测分析表如下
a | b | c | d | # | |
S | S→BA | S→BA | S→BA | ||
A | A→BS | c语言基本名词概念A→BS | A→BS | A→d | |
B | B→aA | B→bS | B→c | ||
给出句子 adccd 的分析过程。
8.写一个文法G, 使其语言为 L(G)={albmclanbn| l>=0, m>=1, n>=2}
9.已知文法G(S):
S→a| (T)
T→T,S|S
的优先关系表如下:
关系 | a | ( | ) | , |
a | - | - | .> | .> |
( | <. | <. | =. | <. |
) | - | - | .> | .> |
, | <. | <. | .> | .> |
请计算出该优先关系表所对应的优先函数表。
10.何谓优化?按所涉及的程序范围可分为哪几级优化?
11.目标代码有哪几种形式?生成目标代码时通常应考虑哪几个问题?
12.一字母表Σ={a, b},试写出Σ上所有以a为首的字组成的正规集相对应的正规式。
13.基本的优化方法有哪几种?
14.写一个文法G, 使其语言为 L(G)={abncn| n≥0}
15.考虑下面的程序:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论