编译原理复题及参考答案Word格式.docx
- 文档编号:21730103
- 上传时间:2023-02-01
- 格式:DOCX
- 页数:22
- 大小:25.68KB
编译原理复题及参考答案Word格式.docx
《编译原理复题及参考答案Word格式.docx》由会员分享,可在线阅读,更多相关《编译原理复题及参考答案Word格式.docx(22页珍藏版)》请在冰豆网上搜索。
)态;
而且实际上至少要有),()和(
)态。
规则进行的。
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)及相应翻译方案
StaAb{print“1”}
Sta{print“2”}
AtAS{print“3”}
Atc{print“4”}
输入acab,输出是什么?
3.已知文法G(S)
StbAa
At(B|a
BtAa)
写出句子b(aa)b的规范归约过程。
4.考虑下面的程序:
procedurep(x,y,z);
begin
y:
=x+y;
z:
=z*z;
end
A:
=2;
B:
=A*2;
P(A,A,B);
PrintA,B
end.
试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出A,B的值是什么?
5.文法G(S)
StdAB
A^aA|a
BtBb|£
描述的语言是什么?
6.证明文法G(S)
StSaS|e
是二义性的。
7.已知文法G(S)
StBA
AtBS|d
BtaA|bS|c
的预测分析表如下
a
b
c
d
#
S
Stba
A
AtBS
Ard
B
BtaA
BtbS
Btc
给出句子adccd的分析过程。
8.写一个文法G,使其语言为L(G)={albmcanbn|l>
=0,m>
=1,n>
=2}
9.已知文法G(S):
Sta|(T)
TtT,S|S
的优先关系表如下:
关系
(
)
5
-
.>
V.
=
J
请计算出该优先关系表所对应的优先函数表。
10.何谓优化?
按所涉及的程序范围可分为哪几级优化?
11.目标代码有哪几种形式?
生成目标代码时通常应考虑哪几个问题?
12.一字母表2={a,b},试写出工上所有以a为首的字组成的正规集相对应的正规式。
13.基本的优化方法有哪几种?
14.写一个文法G,使其语言为L(G)={abncn|n>
0}
15.考虑下面的程序:
procedurep(x,y,z);
=y+z;
=y*z+x
end;
a:
b:
=3;
p(a+b,b,a);
printa
end.
试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出a的值是什么?
16.写出表达式a+b*(c-d)/e的逆波兰式和三元序列。
17.证明文法G(A)
AtAAI(A)|£
18.令》={a,b},则正规式ab|ba表示的正规集是什么?
19•何谓DISPLAY表?
其作用是什么?
20.考虑下面的程序:
procedurep(x,y,z);
=y+2;
=z+x;
=5;
p(a+b,a-b,a);
21.写一个文法G,使其语言为L(G)={anbncmIn>
0为奇数,m>
0为偶数}
22.写出表达式a:
=(b+c)*e+(b+c)/f的逆波兰式和三元序列。
23.—个文法G别是LL
(1)文法的充要条件是什么?
24.已知文法G[S]
StS*aFIaFI*aF
Ft+aFI+a
消除文法左递归和提公共左因子。
25.符号表的作用是什么?
符号表查找和整理技术有哪几种?
五、计算题:
1.设文法G(S):
St卜|a|(T)
TtT,SIS
⑴消除左递归;
⑵构造相应的FIRST和FOLLOW合;
⑶构造预测分析表
2.语句ifEthenS
(1)改写文法,使之适合语法制导翻译;
(2)写出改写后产生式的语义动作。
3.设文法G(S):
St(T)|a
T+S|S
(1)计算FIRSTVT和LASTVT;
(2)构造优先关系表。
4.设某语言的for语句的形式为
fori:
=E
(1)toE⑵doS
其语义解释为
i:
=E
(1)
LIMIT:
=E⑵
again:
ifiv=LIMITthen
Begin
S;
=i+1
gotoagain
End;
(1)写出适合语法制导翻译的产生式;
(2)写出每个产生式对应的语义动作。
5.把语句
whilea<
10do
ifc>
0thena:
=a+1
elsea:
=a*3-1;
翻译成四元式序列。
6.设有基本块
D:
=A-C
E:
=A*C
F:
=D*E
S:
=2
T:
Q:
G:
=2*S
J:
=T*Q
K:
=G*5
L:
=K+J
M:
=L
假设基本块出口时只有M还被引用,请写出优化后的四元序列。
7.已知文法G(S)
Sta|A|(T)
—T,S|S
(1)给出句子(a,(a,a))的最左推导;
(2)给出句型((T,S),a)的短语,直接短语,句柄。
8.对于C语言doSwhileE语句
9.已知文法G(S)
StaAcBe
AtAb|b
Btd
(1)给出句子abbcde的最左推导及画出语法树;
(2)给出句型aAbcde的短语、素短语。
10.设文法G(S):
St(T)|aS|a
TtT,S|S⑴消除左递归和提公共左因子;
⑵构造相应的FIRST和FOLLOW!
合;
⑶构造预测分析表。
11.把语句
ifX>
0VY<
thenwhileX>
0doX:
=A*3
elseY:
=B+3;
翻译成四元式序列。
12.已知文法G(S)
EtE+T|T
TtT*F|F
Ft(E)|i
(1)给出句型(i+i)*i+i的最左推导及画出语法树;
(2)给出句型(E+T)*i+F的短语,素短语和最左素短语。
13.设文法G(S):
StT|SVT
Ttu|T卜'
U
Uti|-U
参考答案
一、是非题:
1.X2.X3.X4.V5.V6.X7.X8.X9.V10.X11.
12.V13.X14.V15.V16.V17.X18.V19.V20.X21.V22.
1.(最右推导)
2.(词法分析),(语法分析),(中间代码生成),(代码优化),(目标代码生成)
3.(二义性的)
4.(执行性),(说明性)
5.(单词符号),(语法单位)。
6.(源程序),(单词符号)
7.(类型、种属、所占单元大小、地址)
8.(现行活动记录地址和所有外层最新活动记录的地址)
9.(句柄)
10.(栈式),(堆式)
11.(类型),(作用域)
12.(传地址),(传值),(传名)
13.(局部优化),(循环优化),(全局优化)
14.(自上而下),(自下而上)
15.(分析表),(符号栈)
16.(传地址),(传值),(传名)
17.(初),(终)
18.(局部优化),(循环优化),(全局优化)
19.(语法),(语义)
20.(句柄)
21.(LL
(1)文法)
22.(静态),(动态)
23.(二义性文法)
24.(规范推导),(规范)
25.(自上而下),(自下而上)
26.(句子)
27.(从开始符号出发,向下推导,推出句子)
28.(单词符号),(语法单位)
29.(局部优化)
30.(分析表),(符号栈)
31.(上下文无关文法),(正规)
32.(指令访问主存次数加1)
33.(最左素短语)
1.局部优化局限于基本块范围的优化称。
2.二义性文法如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义性文法。
3.DISPLAY表过程的嵌套层次显示表,记录该过程的各外层过程的最新活动记录的起始地址。
4.词法分析器执行词法分析的程序。
5.最左推导——任何一步a=>
3都是对a中的最右非终结符替换。
6.语法一组规则,用它可形成和产生一组合式的程序。
7.文法描述语言的语法结构的形式规则。
8.基本块指程序中一顺序执行的语句序列,其中只有一个入口和一个出口,入口就是其中的第一
个语句,出口就是其中的最后一个语句。
9.语法制导翻译------在语法分析过程中,根据每个产生式所对应的语义子程序进行翻译的办法叫做语法制导翻译。
10.短语------令G是一个文法,S划文法的开始符号,假定a3S是文法G的一个句型,如果有S—:
aA3且A则称3是句型a3§
相对非终结符A的短语。
11.待用信息------如果在一个基本块中,四元式i对A定值,四元式j要引用A值,而从i到j之间没
有A的其它定值,则称j是四元式i的变量A的待用信息。
12.规范句型------由规范推导所得到的句型。
13.扫描器------执行词法分析的程序。
14.超前搜索------在词法分析过程中,有时为了确定词性,需超前扫描若干个字符。
15.句柄一个句型的最左直接短语。
16.语法制导翻译------在语法分析过程中,根据每个产生式所对应的语义程序进行翻译的方法叫做语
法制导翻译。
17.规范句型------由规范推导所得到的句型。
18.素短语------素短语是指这样一个短语,至少含有一个终结符,并且,除它自身外不再含任何更小的素短语。
19.语法------是组规则,用它可形成和产生一个合式的程序。
_
20.待用信息------如果在一个基本块中,四元式i对A定值,四元式j要引用A值,而从i到j之间没
21.语义------定义程序的意义的一组规则。
四、简答题:
1.所求文法是G[S]:
StAB|BA0
AtAD|C
Bt2|4|6|8
Ct1|3|5|7|9|B
DT0|C
2.输出是4231
3.句子b(aa)b的规范归约过程:
步骤
符号栈
输入串
动作
b(aa)b#
预备
1
#b
(aa)b#
移进
2
#b(
aa)b#
3
#b(a
a)b#
4
#b(A
归约
#b(Ma
)b#
6
#b(Ma)
b#
7
#b(B
8
#bA
9
#bAb
10
#S
接受
4.传地址A=6,B=16
传值A=2,B=4
5.L(G)={danbm|n>
0,m>
0}
6.证明:
因为文法G[S]存在句子aa有两个不同的最左推导,所以文法G[S]是是二义性的。
S=>
SaS=>
SaSaS=>
aSaS=>
aaS=>
aa
aS=>
7.句子adccd的分析过程:
产生式
adccd#
#AB
#AAa
#AA
dccd#
#Ad
ATd
#A
ccd#
#SB
#Sc
cd#
#Ac
d#
11
12
#d
13
8.所求文法是G[S]:
StAB
AtaAc|D
DTbD|b
BtaBb|aabb
9.
函数
f
g
9.优化:
对程序进行各种等价变换,使得从变换后的程序出发,能产生更有效的目标代码。
三种级别:
局部优化、循环优化、全局优化
10.目标代码通常采用三种形式:
机器语言,汇编语言,待装配机器语言模块。
应着重考虑的问题:
(1)如何使生成的目标代码较短;
(2)如何充分利用寄存器,以减少访问内存次数;
(3)如何充分利用指令系统的特点。
11.正规式a(a|b)*。
12.删除多余运算,代码外提,强度削弱,变换循环控制条件,合并已知量,复写传播和删除无用赋值。
13.文法G[S]:
StaB|a
Btbc|bBc
14.传值a=2传地址a=15
15.逆波兰式:
abcd-*e/+
三元序歹U:
oparg1arg2
(1)-
(2)*
(1)
(3)/
(2)
e
(4)+
(3)
17.证明:
因为文法G[S]存在句子()有两个不同的最左推导,所以文法G[S]是是二义性的。
A=>
AA=>
(A)A=>
()A=>
()
A=>
(A)=>
**
18.(ab|ba)={a,b,ab,ba,aab,bba}
19.Display表:
嵌套层次显示表由于过程嵌套允许内层过程引用外层过程定义的数据,因此,当一个过程运行时必须跟踪它的所有外层过程的最新活动记录起始地址,display表就是用于登记每个外层过程的最新活动记录起始地址。
20.传地址a=12传值a=5
21.所求文法是G[S]:
StAC
2aaAbb|ab
CtccC|cc
22.逆波兰式abc+e*bc+f/+:
三元序列
op
arg1arg2
(1)+
(3)+
(4)/
(5)+
(4)
(6):
(5)
23.一个文法G别是LL
(1)文法的充要条件:
(1)FIRST(a)nFIRST®
)=①
(2)如果3=*>
s,FIRST(a)nFOLLOW(A)*
24.消除左递归
StaFS'
|*aFS'
S'
t*aFS'
|&
Ft+aF|+a提公共左因子,文法G'
(S)
t*aFS'
Ft+aF'
F'
tF|&
25.作用:
登记源程序中出现的各种名字及其信息,以及了解各阶段的进展状况。
主要技术:
线性表,对折查找,杂奏技术。
五、计算题:
1.
(1)消除左递,文法变为G'
[S]:
St|a|(T)'
TtST'
|S
T'
t,ST'
此文法无左公共左因子。
(2)构造相应的FIRST和FOLLOW集合:
FIRST(S)={a,A,(},FOLLOW(S)={#,,,)}
FIRST(T)={a,A,(},FOLLOW(T)={}}
FIRST(T'
)={,,£
},FOLLOW(F)={)}
(3)构造预测分析表:
STa
St人
St(T)'
T
Ttst'
TtST'
t£
t,ST'
2.
(1)
ifEthen
StCS
(1)
CtifEthen{BACK(E.TC,NXQ);
C.chain:
=E.FC}
(1)
(1)
StCS(1{S.chain:
=MERG(C.Chain,S.Chain)}
3.
(1)FIRSTVT(S)={a,(}
FIRSTVT(T)={+,aa,(}
LASTVT(S)={a,)}
LASTVT(T)={+,a,)}
+
>
.
4.
(1)Ftfori:
=E
(1)toE⑵do
StFS
(1)
(2)Ftfori:
{GEN(:
=,E
(1).place,_,entry(i));
F.place:
=entry(i);
LIMIT:
=Newtemp;
GEN(:
=,E⑵.place,_,LIMIT);
Q:
=NXQ;
F.QUAD:
=q;
GEN(j<
entry(i),LIMIT,q+2)F.chain:
GEN(j,_,_,0)}
{BACKPATCH(S.chain,NXQ);
GEN(+,F.place,1,F.place);
GEN(j,_,_,F.QUAD);
S.chain:
=F.chain
}
5.
(1)(j<
a,‘10'
(3))
(2)(j,_,_,(12))
(3)(j>
c,‘O'
(5))
(4)(j,_,_,(8))
(5)(+,a,‘1’,T1))
(6)(:
=,T1,_,a)
(7)(j,_,_,
(1))
(8)(*,a,'
13'
T2)
(9)(-,T2,‘1'
T3)
(10)(:
=,T3,_,a)
(11)(j,亠,
(1))
6.优化后的四元序列
=F+20
7.最
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 原理 参考答案