当前位置:
文档之家› 郑州大学编译原理试卷及答案(往年试题整合)
郑州大学编译原理试卷及答案(往年试题整合)
2.编译过程可分为(词法分析),(语法分析),(中间代码生成),(代码优化)和(目标代码生成)五个阶段。
3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是(二义性的)。
4.从功能上说,程序语言的语句大体可分为(执行性)语句和(说明性)语句两大类。
5.语法分析器的输入是(单词符号),其输出是(语法单位)。
所求文法是G[S]: S→AB A→aAc | D D→bD | b B→aBb | aabb
9.已知文法G(S): S→a| (T) T→T,S|S
的优先关系表如下:
关系a ( ) , a - - .> .> ( <. <. =. <. ) - - .> .> , <. <. .> .>
请计算出该优先关系表所对应的优先函数表。
21.写一个文法G,使其语言为L(G)={anbncm| n>0为奇数,m>0为偶数}21.所求文法是G[S]: S→AC A→aaAbb | ab C→ccC | cc
22.写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列。
23.一个文法G别是LL(1)文法的充要条件是什么?23.一个文法G别是LL(1)文法的充要条件是: (1) FIRST(α)∩FIRST(β)=Ф
11.一个名字的属性包括(类型)和(作用域)。
12.常用的参数传递方式有(传地址),(传值)和(传名)。
13.根据优化所涉及的程序范围,可将优化分成为(局部优化),(循环优化)和(全局优化)三个级别。
14.语法分析的方法大致可分为两类,一类是(自上而下)分析法,另一类是(自下而上)分析法。
15.预测分析程序是使用一张(分析表)和一个(符号栈)进行联合控制的。
4.表达式x+y*z/(a+b)的后缀式为(xyz*ab+/+)。
5.文法符号的属性有综合属性和(继承属性)。
6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..20]某个元素a[i,j]的地址计算公式为(a+(i-1)*20+j-1)。
7.局部优化是局限于一个(基本块)范围内的一种优化。
(1)给出句子(()())()()的规范推导过程;(4分)
(2)指出每步推导所得句型的句柄;(1)中加下划线的部分是句柄,标识如(1)
画出该句子的语法推导树。
1.写一个文法G,使其语言为不以0开头的偶数集。
所求文法是G[S]:
S→AB |B A0 A→AD |CB→2 |4 |6 |8
C→1 |3 |5 |7 |9 |B D→0 |C
16.常用的参数传递方式有(传地址),(传值)和(传名)。
17.一张转换图只包含有限个状态,其中有一个被认为是(初)态;而且实际上至少要有一个(终)态。
18.根据优化所涉及的程序范围,可将优化分成为(局部优化),(循环优化)和(全局优化)三个级别。
19.语法分析是依据语言的(语法)规则进行。中间代码产生是依据语言的(语义)规则进行的。
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的值是什么?传地址A=6, B=16传值A=2, B=4
20.一个句型的最左直接短语称为句型的(句柄)。
21.一个文法G,若它的预测分析表M不含多重定义,则该文法是LL(1)文法)文法。
22.对于数据空间的存贮分配,FORTRAN采用(静态)策略,PASCAL采用(动态)策略。
23.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是(二义性文法)。
四、综合题:
1、已知正规式1(0|1)*101构造一个最小化的DFA。
2、已知文法G[A]:A→(A)|a,构造该文法的LR(0)分析表。
24.最右推导亦称为(规范推导),由此得到的句型称为(规范)句型。
25.语法分析的方法大致可分为两类,一类是(自上而下)分析法,另一类是(自下而上)分析法。
26.对于文法G,仅含终结符号的句型称为(句子)。
27.所谓自上而下分析法是指(从开始符号出发,向下推导,推出句子)。
28.语法分析器的输入是(单词符号),其输出是(语法单位)。
二填空题
1.不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静态存储分配方案和动态存储分配方案,而后者又分为(栈式动态存储分配)和(堆式动态存储分配)。
2.规范规约是最(左)规约。
3.编译程序的工作过程一般划分为5个阶段:词法分析、(语法分析)、语义分析与中间代码生成,代码优化及(目标代码生成)。另外还有(表格管理)和出错处理。
(2)如果β=*>ε, FIRST(α)∩FOLLOW(A)=Ф
24.已知文法G[S]
S→S*aF | aF | *aFF→+aF | +a
消除文法左递归和提公共左因子。24.消除左递归
S→aFS’| *aFS’S’→*aFS’|εF→+aF | +a
提公共左因子,文法G’(S) S→aFS’| *aFS’S’→*aFS’|εF→+aF’F’→F |ε
FOLLOW(E)={),*,+,#} FOWLLOW(E’)= {),*,+,#} FOLLOW(T)={(,i}
(3)构造LL(1)分析表。
(
)
i
*
+
#
E
E→(E)E’
E→iபைடு நூலகம்’
E’
E’→ ε
E’→TEE’
E’ →ε
E’→TEE’
E’ →ε
E’ →ε
T
T→*
T→+
2.(共12分)给定文法G[S]:S→S(S)|ε
29.局限于基本块范围的优化称(局部优化)。
30.预测分析程序是使用一张(分析表)和一个(符号栈)进行联合控制的。
31.2型文法又称为(上下文无关文法)文法;3型文法又称为(正规)文法。
32.每条指令的执行代价定义为(指令访问主存次数加1)。33.算符优先分析法每次都是对(最左素短语)进行归约。
三.解答题1.已知文法G[E]:
25.符号表的作用是什么?符号表查找和整理技术有哪几种?
25.作用:登记源程序中出现的各种名字及其信息,以及了解各阶段的进展状况。
主要技术:线性表,对折查找,杂奏技术。
三、简答题:
1、已知文法G[E]
E->E+T|E-T|T T->T*F|T/F|F F->(E)|i
证明(F+T)-T*(E-T)是文法的句型,并给出该句型的短语、直接短语和句柄。
2、给出语句While(A<B)Do
If(C<D)then X=Y+Z的四元式序列。
四元式序列为:
3、消除该文件的左递归:S->Aa|bA->Ac|Sd
S->Aa|b
A->bdA' | A'
A'->cA' | adA'|ε
4、已知文法G:S->aBc|bAB A->aAb|b B->b|
判断该文法是否是LL(1)文法,并说明理由。
E→ETE|(E)|i T→*|+
(1)将文法G改造成LL(1)文法;
(1)文法存在左递归,消除左递归后的文法为:
E→(E)E’|i E’E’→TEE’|εT→*|+
(2)构造文法G中每个非终结符的FIRST集合及FOLLOW集合;FIRST(E)={(,i} FIRST(E’)={*,+, ε} FIRST(T)={*,+}
14.文法G[S]: S→aB | a B→bc |bBc
15.考虑下面的程序:„
procedure p(x, y, z); begin y:=y+z; z:=y*z+x end; begin a:=2; b:=3;
p(a+b, b, a); print a end.
试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出a的值是什么?15.传值a=2传地址a=15
20.考虑下面的程序:
„procedure p(x, y, z);begin y:=y+2; z:=z+x; end begin
a:=5; b:=2;
p(a+b, a-b, a); print a end.
试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出a的值是什么?20.传地址a=12传值a=5
6.扫描器的任务是从(源程序)中识别出一个个(单词符号)。
7.符号表中的信息栏中登记了每个名字的有关的性质,如(类型、种属、所占单元大小、地址)等等。
8.一个过程相应的DISPLAY表的内容为(现行活动记录地址和所有外层最新活动记录的地址)。
9.一个句型的最左直接短语称为句型的(句柄)。
10.常用的两种动态存贮分配办法是(栈式)动态分配和(堆式)动态分配。
8词法规则通常可以用____正规式________,正规文法、____自动机________描述;语法规则通常用___2型文法___来描述;语义规则通常用__属性文法_____来描述。
9编译原理的工作过程一般划分为:词法分析、语法分析、语义分析、优化和目标代码生成五个阶段。
1.(最右推导)称为规范推导。
7.已知文法G(S) S→BA A→BS| d
B→aA| bS | c的预测分析表如下