《编译原理》复习题及答案Word文件下载.docx
- 文档编号:17650779
- 上传时间:2022-12-07
- 格式:DOCX
- 页数:21
- 大小:26.34KB
《编译原理》复习题及答案Word文件下载.docx
《《编译原理》复习题及答案Word文件下载.docx》由会员分享,可在线阅读,更多相关《《编译原理》复习题及答案Word文件下载.docx(21页珍藏版)》请在冰豆网上搜索。
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→c{print“4”}
输入acab,输出是什么?
3.已知文法G(S)
S→bAa
A→(B|a
B→Aa)
写出句子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]
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
A
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
(
)
-
.>
<
.
=.
请计算出该优先关系表所对应的优先函数表。
10.何谓优化?
按所涉及的程序范围可分为哪几级优化?
11.目标代码有哪几种形式?
生成目标代码时通常应考虑哪几个问题?
12.一字母表Σ={a,b},试写出Σ上所有以a为首的字组成的正规集相对应的正规式。
13.基本的优化方法有哪几种?
14.写一个文法G,使其语言为L(G)={abncn|n≥0}
15.考虑下面的程序:
procedurep(x,y,z);
begin
y:
=y+z;
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]
A→AA|(A)|ε
18.令Σ={a,b},则正规式a*b|b*a表示的正规集是什么?
19.何谓DISPLAY表?
其作用是什么?
20.考虑下面的程序:
…
procedurep(x,y,z);
=y+2;
=z+x;
a:
=5;
b:
p(a+b,a-b,a);
printa
21.写一个文法G,使其语言为L(G)={anbncm|n>
0为奇数,m>
0为偶数}
22.写出表达式a:
=(b+c)*e+(b+c)/f的逆波兰式和三元序列。
23.一个文法G别是LL
(1)文法的充要条件是什么?
24.已知文法G[S]
S→S*aF|aF|*aF
F→+aF|+a
消除文法左递归和提公共左因子。
25.符号表的作用是什么?
符号表查找和整理技术有哪几种?
五、计算题:
1.设文法G[S]:
S→^|a|(T)
T→T,S|S
⑴消除左递归;
⑵构造相应的FIRST和FOLLOW集合;
⑶构造预测分析表
2.语句ifEthenS
(1)改写文法,使之适合语法制导翻译;
(2)写出改写后产生式的语义动作。
3.设文法G[S]:
S→(T)|a
T→T+S|S
(1)计算FIRSTVT和LASTVT;
(2)构造优先关系表。
4.设某语言的for语句的形式为
fori:
=E
(1)toE
(2)doS
其语义解释为
i:
=E
(1)
LIMIT:
=E
(2)
again:
ifi<=LIMITthen
Begin
S;
i:
=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)
S→a|^|(T)
T→T,S|S
(1)给出句子(a,(a,a))的最左推导;
(2)给出句型((T,S),a)的短语,直接短语,句柄。
8.对于C语言doSwhileE语句
9.已知文法G[S]:
S→aAcBe
A→Ab|b
B→d
(1)给出句子abbcde的最左推导及画出语法树;
(2)给出句型aAbcde的短语、素短语。
10.设文法G[S]:
S→(T)|aS|a
⑴消除左递归和提公共左因子;
⑵构造相应的FIRST和FOLLOW集合;
⑶构造预测分析表。
11.把语句
ifX>
0∨Y<
thenwhileX>
0doX:
=A*3
elseY:
=B+3;
12.已知文法G[S]:
E→E+T|T
T→T*F|F
F→(E)|i
(1)给出句型(i+i)*i+i的最左推导及画出语法树;
(2)给出句型(E+T)*i+F的短语,素短语和最左素短语。
13.设文法G[S]:
S→T|S∨T
T→U|T∧U
U→i|-U
参考答案
1.×
2.×
3.×
4.√5.√6.×
7.×
8.×
9.√10.×
11.×
12.√13.×
14.√15.√16.√17.×
18.√19.√20.×
21.√22.√
1.(最右推导)
2.(词法分析),(语法分析),(中间代码生成),(代码优化),(目标代码生成)
3.(二义性的)
4.(执行性),(说明性)
5.(单词符号),(语法单位)。
6.(源程序),(单词符号)
7.(类型、种属、所占单元大小、地址)
8.(现行活动记录地址和所有外层最新活动记录的地址)
9.(句柄)
10.(栈式),(堆式)
11.(类型),(作用域)
12.(传地址),(传值),(传名)
13.(局部优化),(循环优化),(全局优化)
14.(自上而下),(自下而上)
15.(分析表),(符号栈)
16.(传地址),(传值),(传名)
17.(初),(终)
18.9局部优化),(循环优化),(全局优化)
19.(语法),(语义)
20.(句柄)
21.(LL
(1)文法)
22.(静态),(动态)
23.(二义性文法)
24.(规范推导),(规范)
25.(自上而下),(自下而上)
26.(句子)
27.(从开始符号出发,向下推导,推出句子)
28.(单词符号),(语法单位)
29.(局部优化)
30.(分析表),(符号栈)
31.(上下文无关文法),(正规)
32.(指令访问主存次数加1)
33.(最左素短语)
1.局部优化:
局限于基本块范围的优化称。
2.二义性文法:
如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义性文法。
3.DISPLAY表:
过程的嵌套层次显示表,记录该过程的各外层过程的最新活动记录的起始地址。
4.词法分析器:
执行词法分析的程序。
5.最左推导:
任何一步α=>
β都是对α中的最右非终结符替换。
6.语法:
一组规则,用它可形成和产生一组合式的程序。
7.文法:
描述语言的语法结构的形式规则。
8.基本块:
指程序中一顺序执行的语句序列,其中只有一个入口和一个出口,入口就是其中的第一个语句,出口就是其中的最后一个语句。
9.语法制导翻译:
在语法分析过程中,根据每个产生式所对应的语义子程序进行翻译的办法叫做语法制导翻译。
10.短语:
令G是一个文法,S划文法的开始符号,假定αβδ是文法G的一个句型,如果有S
αAδ且A
β,则称β是句型αβδ相对非终结符A的短语。
11.待用信息:
如果在一个基本块中,四元式i对A定值,四元式j要引用A值,而从i到j之间没有A的其它定值,则称j是四元式i的变量A的待用信息。
12.规范句型:
由规范推导所得到的句型。
13.扫描器:
14.超前搜索:
在词法分析过程中,有时为了确定词性,需超前扫描若干个字符。
15.句柄:
一个句型的最左直接短语。
16.语法制导翻译:
在语法分析过程中,根据每个产生式所对应的语义程序进行翻译的方法叫做语法制导翻译。
17.规范句型:
18.素短语:
素短语是指这样一个短语,至少含有一个终结符,并且,除它自身外不再含任何更小的素短语。
19.语法:
是组规则,用它可形成和产生一个合式的程序。
20.待用信息:
21.语义:
定义程序的意义的一组规则。
1.所求文法是G[S]:
S→AB|BA0
A→AD|C
B→2|4|6|8
C→1|3|5|7|9|B
D→0|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
归约
5
#b(Ma
b)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
S=>
aS=>
7.句子adccd的分析过程:
产生式
adccd#
#AB
#AAa
#AA
dccd#
#Ad
#A
ccd#
#SB
#Sc
ccd#
B→c
cd#
#Ac
d#
11
#A
12
#d
13
#
8.所求文法是G[S]:
S→AB
A→aAc|D
D→bD|b
B→aBb|aabb
9.
函数
f
g
10.优化:
对程序进行各种等价变换,使得从变换后的程序出发,能产生更有效的目标代码。
三种级别:
局部优化、循环优化、全局优化
11.目标代码通常采用三种形式:
机器语言,汇编语言,待装配机器语言模块。
应着重考虑的问题:
(1)如何使生成的目标代码较短;
(2)如何充分利用寄存器,以减少访问内存次数;
(3)如何充分利用指令系统的特点。
12.正规式a(a|b)*。
13.删除多余运算,代码外提,强度削弱,变换循环控制条件,合并已知量,复写传播和删除无用赋值。
14.文法G[S]:
S→aB|a
B→bc|bBc
15.传值a=2
传地址a=15
16.逆波兰式:
abcd-*e/+
三元序列:
oparg1arg2
(1)-cd
(2)*b
(1)
(3)/
(2)e
(4)+a(3)
17.证明:
因为文法G[S]存在句子()有两个不同的最左推导,所以文法G[S]是是二义性的。
A=>
AA=>
(A)A=>
()A=>
()
A=>
(A)=>
18.(a*b|b*a)={a,b,ab,ba,aab,bba……}
19.Display表:
嵌套层次显示表
由于过程嵌套允许内层过程引用外层过程定义的数据,因此,当一个过程运行时必须跟踪它的所有外层过程的最新活动记录起始地址,display表就是用于登记每个外层过程的最新活动记录起始地址。
20.传地址a=12
传值a=5
21.所求文法是G[S]:
S→AC
A→aaAbb|ab
C→ccC|cc
22.逆波兰式abc+e*bc+f/+:
=
三元序列oparg1arg2
(1)+bc
(2)*
(1)e
(3)+bc
(4)/(3)f
(5)+
(2)(4)
(6):
=a(5)
23.一个文法G别是LL
(1)文法的充要条件是:
(1)FIRST(α)∩FIRST(β)=Ф
(2)如果β=*>
ε,FIRST(α)∩FOLLOW(A)=Ф
24.消除左递归
S→aFS’|*aFS’
S’→*aFS’|ε
提公共左因子,文法G’[S]
F→+aF’
F’→F|ε
25.作用:
登记源程序中出现的各种名字及其信息,以及了解各阶段的进展状况。
主要技术:
线性表,对折查找,杂奏技术。
1.
(1)消除左递,文法变为G’[S]:
S→^|a|(T)'
T→ST’|S
T’→,ST’|ε
此文法无左公共左因子。
(2)构造相应的FIRST和FOLLOW集合:
FIRST(S)={a,^,(},FOLLOW(S)={#,,,)}
FIRST(T)={a,^,(},FOLLOW(T)={}}
FIRST(T’)={,,ε},FOLLOW(F)={)}
(3)构造预测分析表:
^
S
S→a
S→^
S→(T)'
T
T→ST’
T’
T’→ε
T’→,ST’
2.
(1)
C→ifEthen
S→CS
(1)
(2)
C→ifEthen{BACK(E.TC,NXQ);
C.chain:
=E.FC}
S→CS
(1){S.chain:
=MERG(C.Chain,S
(1).Chain)}
3.
(1)FIRSTVT(S)={a,(}
FIRSTVT(T)={+,aa,(}
LASTVT(S)={a,)}
LASTVT(T)={+,a,)}
+
(
)
.>
+
<
=.
>
4.
(1)F→fori:
=E
(1)toE
(2)do
S→FS
(1)
(2)F→fori:
{GEN(:
=,E
(1).place,_,entry(i));
F.place:
=entry(i);
LIMIT:
=Newtemp;
GEN(:
=,E
(2).place,_,LIMIT);
=NXQ;
F.QUAD:
=q;
GEN(j≤,entry(i),LIMIT,q+2)
F.chain:
GEN(j,_,_,0)}
S→FS
(1)
{BACKPATCH(S
(1).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,‘0’,(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))
(12)
6.优化后的四元序列
=F+20
7.最左推导
S=(T)=>
(T,S)=>
(S,S)=>
(a,S)=>
(a,(T))=>
(a,(T,S))=>
(a,(S,S))=>
(a,(a,S))=>
(a,(a,a))
短语
((T,S),a)
(T,S),a
(T,S)
T,S
直接短语
句柄
8.
(1)
S→doM1S1whileM2E
M→ε
M→ε{M.quad=nestquad;
S→doM1S1whileM2E{backpatch(s1.nextlist,M2.quad);
backpatch(E.truelist,M1.quad);
S.nextlist=E.falelist;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译原理 编译 原理 复习题 答案