编译原理习题及答案(整理后)

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第一章
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、b 8、c 9、d 10、c
多选解答
1.b、c 2、a、b、c、e
填空解答
就是否生成目标程序2、词法分析中间代码生成3、源程序目标代码生成4、源程序
目标语言
第二章
一、单项选择题
1、文法G:S→xSx|y所识别得语言就是。

a、xyx
b、(xyx)*
c、x n yx n(n≥0)
d、x*yx*
2、文法G描述得语言L(G)就是指。

a、L(G)={α|S+⇒α , α∈V T*}
b、L(G)={α|S*⇒α, α∈V T*}
c、L(G)={α|S*⇒α,α∈(V T∪V N*)}
d、L(G)={α|S+⇒α, α∈(V T∪V N*)}
3、有限状态自动机能识别。

a、上下文无关文法
b、上下文有关文法
c、正规文法
d、短语文法
4、设G为算符优先文法,G得任意终结符对a、b有以下关系成立。

a、若f(a)>g(b),则a>b
b、若f(a)<g(b),则a<b
c、a~b都不一定成立
d、a~b一定成立
5、如果文法G就是无二义得,则它得任何句子α。

a、最左推导与最右推导对应得语法树必定相同
b、最左推导与最右推导对应得语法树可能不同
c、最左推导与最右推导必定相同
d、可能存在两个不同得最左推导,但它们对应得语法树相同
6、由文法得开始符经0步或多步推导产生得文法符号序列就是。

a、短语
b、句柄
c、句型
d、句子
7、文法G:E→E+T|T
T→T*P|P
P→(E)|I
则句型P+T+i得句柄与最左素短语为。

a、P+T与i
b、P与P+T
c、i与P+T+i
d、P与T
8、设文法为:S→SA|A
A→a|b
则对句子aba,下面就是规范推导。

a、S⇒SA⇒SAA⇒AAA⇒aAA⇒abA⇒aba
b、S⇒SA⇒SAA⇒AAA⇒AAa⇒Aba⇒aba
c、S⇒SA⇒SAA⇒SAa⇒Sba⇒Aba⇒aba
d、S⇒SA⇒Sa⇒SAa⇒Sba⇒Aba⇒aba
9、文法G:S→b|∧(T)
T→T,S|S
则FIRSTVT(T) 。

a、{b,∧,(}
b、{b,∧,)}
c、{b,∧,(,,}
d、{b,∧,),,}
10、产生正规语言得文法为。

a、0型
b、1型
c、2型
d、3型
11、采用自上而下分析,必须。

a、消除左递归
b、消除右递归
c、消除回溯
d、提取公共左因子
12、在规范归约中,用来刻画可归约串。

a、直接短语
b、句柄
c、最左素短语
d、素短语
13、有文法G:E→E*T|T
T→T+i|i
句子1+2*8+6按该文法G归约,其值为。

a、23 B、42 c、30 d、17
14、规范归约指。

a、最左推导得逆过程
b、最右推导得逆过程
c、规范推导
d、最左归约得逆过程
二、多项选择题
1、下面哪些说法就是错误得。

a、有向图就是一个状态转换图
b、状态转换图就是一个有向图
c、有向图就是一个DFA
d、DFA可以用状态转换图表示
2、对无二义性文法来说,一棵语法树往往代表了。

a、多种推导过程
b、多种最左推导过程
c、一种最左推导过程
d、仅一种推导过程
e、一种最左推导过程
3、如果文法G存在一个句子,满足下列条件之一时,则称该文法就是二义文法。

a、该句子得最左推导与最右推导相同
b、该句子有两个不同得最左推导
c、该句子有两棵不同得最右推导
d、该句子有两棵不同得语法树
e、该句子得语法树只有一个
4、有一文法G:S→AB
A→aAb|ε
B→cBd|ε
它不产生下面集合。

a、{a n b m c n d m|n,m≥0}
b、{a n b n c m d m|n,m>0}
c、{a n b m c m d n|n,m≥0}
d、{a n b n c m d m|n,m≥0}
e、{a n b n c n d n|n≥0}
5、自下而上得语法分析中,应从开始分析。

a、句型
b、句子
c、以单词为单位得程序
d、文法得开始符
e、句柄
6、对正规文法描述得语言,以下有能力描述它。

a、0型文法
b、1型文法
c、上下文无关文法
d、右线性文法
e、左线性文法
三、填空题
1、文法中得终结符与非终结符得交集就是。

词法分析器交给语法分析器得文法符号一定就是,它一定只出现在产生式得部。

2、最左推导就是指每次都对句型中得非终结符进行扩展。

3、在语法分析中,最常见得两种方法一定就是分析法,另一就是分析法。

4、采用语法分析时,必须消除文法得左递归。

5、树代表推导过程,树代表归约过程。

6、自下而上分析法采用、归约、错误处理、等四种操作。

7、Chomsky把文法分为种类型,编译器构造中采用与文法,它们分别产生与语言,并分别用与自动机识别所产生得语言。

四、判断题
1、文法S→aS|bR|ε描述得语言就是(a|bc)* ( )
R→c S
2、在自下而上得语法分析中,语法树与分析树一定相同。

()
3、二义文法不就是上下文无关文法。

()
4、语法分析时必须先消除文法中得左递归。

()
5、规范归约与规范推导就是互逆得两个过程。

()
6、一个文法所有句型得集合形成该文法所能接受得语言。

()
五、简答题
1、句柄
2、素短语
3、语法树
4、归约
5、推导
六、问答题
1、给出上下文无关文法得定义。

2、文法G[S]:
S→aSPQ|abQ
QP→PQ
bP→bb
bQ→bc
cQ→cc
(1)它就是Chomsky哪一型文法?
(2)它生成得语言就是什么?
3、按指定类型,给出语言得文法。

L={a i b j|j>i≥1}得上下文无关文法。

4、有文法G:S→aAcB|Bd
A→AaB|c
B→bScA|b
(1)试求句型aAaBcbbdcc与aAcbBdcc得句柄;
(2)写出句子acabcbbdcc得最左推导过程。

5、对于文法G[S]:
S→(L)|aS|a L→L, S|S
(1)画出句型(S,(a))得语法树。

(2)写出上述句型得所有短语、直接短语、句柄与素短语。

6、考虑文法G[T]:
T→T*F|F
F→F↑P|P
P→(T)|i
证明T*P↑(T*F)就是该文法得一个句型,并指出直接短语与句柄。

单选[解答]
1、选c。

2、选a。

3、选c。

4、虽然a与b没有优先关系,但构造优先函数后,a与b就一定存在优先关系了。

所以,由f(a)>g)(b)或f(a)<g(b)并不能判定原来得a与b之间就是否存在优先关系:故选c。

5、如果文法G无二义性,则最左推导就是先生长右边得枝叶:对于d,如果有两个不同得就是了左推导,则必然有二义性。

故选a。

6、选c。

7、由图2-8-1得语法树与优先关系可以瞧出应选b。

8、规范推导就是最左推导,故选d。

9、由T→T,…与T→(…得FIRSTVT(T))={(,,)};
由T→S得FIRSTVT(S)⊂FIRSTVT(T),而
FIRSTVT(T)={b,∧,(,,};因此选c。

10、d 11、c 12、b 13、b 14、b
多选解答1、e、a、c 2、a、c、e 3、b、c、d 4、a
填空解答1、空集终结符右
2、最左
3、自上而上自下而上
4、自上而上
5、语法分析
6、移进接受
7、4 2 型3型上下文无关语言正规语言下推自动机有限
判断解答1、对2、错3、错4、错5、错6、错
简答[解答]
1、句柄:一个句型得最左直接短语称为该句型得句柄。

2、素短语:至少含有一个终结符得素短语,并且除它自身之外不再含任何更小得素短语。

3、语法树:满足下面4个条件得树称之为文法G[S]得一棵语法树。

①每一终结均有一标记,此标记为V N∪V T中得一个符号;
②树得根结点以文法G[S]得开始符S标记;
③若一结点至少有一个直接后继,则此结点上得标记为V N中得一个符号;
④若一个以A为标记得结点有K个直接后继,且按从左至右得顺序,这些结点得标记分别
为X1,X2,…,X K,则A→X1,X2,…,X K,必然就是G得一个产生式。

4、归约:我们称αγβ直接归约出αAβ,仅当A→γ就是一个产生式,且α、β∈(V N∪
V T)*。

归约过程就就是从输入串开始,反复用产生式右部得符号替换成产生式左部符号,直至文法开始符。

5、推导:我们称αAβ直接推出αγβ,即αAβ⇒αγβ,仅当A→γ就是一个产生式,
且α、β∈(V N∪V T)*。

如果α1⇒α2⇒…⇒αn,则我们称这个序列就是从α1至α2得一个推导。

若存在一个从α1αn得推导,则称α1可推导出αn。

推导就是归约得逆过程。

问答1[解答]
一个上下文无关文法G就是一个四元式(V T,V N,S, P),其中:
●V T就是一个非空有限集,它得每个元素称为终结符号;
●V N就是一个非空有限集,它得每个元素称为非终结符号,V T∩V N=Φ;
●S就是一个非终结符号,称为开始符号;
●P就是一个产生式集合(有限),每个产生式得形式就是P→α,其中,P∈V N,
α∈(V T∪V N)*。

开始符号S至少必须在某个产生式得左部出现一次。

2[解答]
(1)由于产生式左部存在终结符号,且所有产生式左部符号得长度均小于等于产生式右部得符号长度,所以文法G[S]就是Chomsky1型文法,即上下文有关文法。

(2)按产生式出现得顺序规定优先级由高到低(否则无法推出句子),我们可以得到:
S⇒abQ⇒abc
S⇒aSPQ⇒aabQPQ⇒aabPQQ⇒aabbQQ⇒aabbcQ⇒aabbcc
S⇒aSPQ⇒aaSPQPQ⇒aaabQPQPQ⇒aaabPQQPQ⇒aaabPQPQQ⇒aaaPPQQQ⇒
aaabbPqqq⇒aaabbQQQ⇒aaabbbcQQ⇒aaabbbccQ⇒aaabbbccc
……
于就是得到文法G[S]生成得语言L={a n b n c n|n≥1}
3【解答】
(1)由L={a i b j|j>i≥1}知,所求该语言对应得上下文无关文法首先应有S→aSb型产生式,以保证b得个数不少于a得个数;其次,还需有S→Sb或S→bS型得产生式,用以保证b得个数多于a得个数;也即所求上下文无关文法G[S]为:
G[S]:S→aSb|Sb|b
4【解答】(1)分别画出对应两句型得语法树,如图2-8-2所示
句柄:AaB Bd
5
(1
(2
③句柄:S ;
④素短语:素短语可由图2-8-3中相邻终结符之间得优先关系求得,即;
因此素短语为
6【解答】首先构造T*P ↑(T*F )得语法树如图2-8-4所示。

由图2-8-4可知,T*P ↑(T*F )就是文法G[T]直接短语有两个,即P 与T*F ;句柄为P 。

第三章
一、单项选择题 1、词法分析所依据得就是 。

a 、 语义规则 b 、 构词规则 c 、 2、词法分析器得输出结果就是 。

a 、 单词得种别编码 b 、 c 、 单词得种别编码与自身值 d 、 单词自身值3、正规式M 1与M 2等价就是指 。

a 、 M 1与M 2得状态数相等
b 、 M 1与M 2得有向弧条数相等
c 、 M 1与M 2所识别得语言集相等
d 、 M 1与M 2状态数与有向弧条数相等 4、状态转换图(见图3-6-1)接受得字集为 。

a 、 以 0结尾得二进制数组成得集合
c 、 含奇数个00得二进制数组成得集合
5、词法分析器作为独立得阶段使整个编译程序结构更加简洁、明确,因此, 。

a 、
b 、 词法分析器作为子程序较好
c 、
d 、 词法分析器并不作为一个独立得阶段
二、多项选择题
1、在词法分析中,能识别出 。

a 、 基本字 b 、 四元式 c 、 运算符 d 、 逆波兰式 e 、 常数
2、令∑={a,b},则∑上所有以b 开头,后跟若干个ab 得字得全体对应得正规式为 。

a 、 b(ab)* b 、 b(ab)+ c 、(ba)*b
d 、 (ba)+
b e 、 b(a|b) 三、填空题
1、确定有限自动机DFA 就是 得一个特例。

2、若二个正规式所表示得 相同,则认为二者就是等价得。

3、一个字集就是正规得,当且仅当它可由 所 。

四、判断题
1、一个有限状态自动机中,有且仅有一个唯一终态。

( )
2、设r 与s 分别就是正规式,则有L (r|s )=L(r)|L(s)。

( )
3、自动机M 与M ′得状态数不同,则二者必不等价。

( )
4、确定得自动机以及不确定得自动机都能正确地识别正规集。

( )
5、对任意一个右线性文法G ,都存在一个NFA M ,满足L(G)=L(M)。

( )
6、对任意一个右线性文法G ,都存在一个DFA M ,满足L(G)=L(M)。

( )
7、对任何正规表达式e ,都存在一个NFA M ,满足L(G)=L(e)。

( )
8、对任何正规表达式e ,都存在一个DFA M ,满足L(G)=L(e)。

( ) 五、基本题
1、设M =({x,y}, {a,b}, f,x,{y})为一非确定得有限自动机,其中f 定义如下:
f (x,a )={x,y} f (x,b )={y} f (y,a )=φ f (y,b )={x,y}
试构造相应得确定有限自动机M ′。

2、对给定正规式b*(d|ad )(b|ab )+,构造其NFA M ; 单选解答 1、b 2、c 3、c 4、d 5、b
图3-6-7 得NFA M 多选解答 1、a 、c 、e 2、a 、b 、d
填空解答 1、NFA 2、正规集 3、DFA (NFA )所识别 判断解答 1 、2、3、错 4、5、6、7、8、正确
基本1解答:对照自动机得定义M=(S,Σ,f,S 0,Z),由f 得定义可知f(x,a)、f(y,b)均为多值函数,所以即得到M ′=将图3-6-5得与非终态组{0}把原来到达2简DFA M ′。

2解答:首先用A 该正规式得1、 D → TL
T → int | real L→ id R
R→ , id R | ε
2、 下面文法S → P → d P | ε
3、 G[S] (1)求出该文法得每一个非终结符U 得FOLLOW 集。

(2)该文法就是LL (1)文法吗? (3)构造C[S]得LL (1)分析表。

4、 将文法G[V]改造成为LL(1)得。

G[V]:V →N|N[E] E →V|V+E N →i
5、已知文法:
G[A]:A→aAa|ε
(1)该文法就是LL(1)文法吗?为什么?
(2)若采用LL(1)方法进行语法分析,如何得到该文法得LL(1)分析表?
(3)若输入符号串“aaaa”,请给出语法分析过程。

1解答:LL(1)分析表见表4-3-1
分析虽然这个文法很简单,我们还就是从求开始符号集合与后继符号集合开始。

FIRST(D)=FIRST(T)={int, real} FOLLOW(D)=FOLLOW(L)={#}
FIRST(L)={id} FOLLOW(T)={id}
FIRST(R)={,, ε} FOLLOW(R)={#}
有了上面每个非终结符得FIRST集合,填分析表时要计算一个产生式右部α得FIRST(α)就不就是件难事了。

填表时唯一要小心得时,ε就是产生式R→ε右部得一个开始符号,而#在FOLLOW(R)中,所以R→ε填在输入符号#得栏目中。

表4-3-1 LL(1)分析表
分析只有三个非终结符有两个选择。

1、P得两个右部d P 与ε 得开始符号肯定不相交。

2、Q得两个右部a Q 与ε 得开始符号肯定不相交。

3、对S来说,由于x ∈ FIRST(A B),同时也有x ∈ FIRST(P Q x)(因为P与Q都可能为空)。

所以该文法不就是LL(1)文法。

3解答:(1)求文法得每一个非终结符U得FOLLOW集得过程如下:
因为:
①S就是识别符号,且有A→BSD、B→SAc、D→Se,所以FOLLOW(S)应包含
FIRST(D)∪FIRST(Ac) ∪FIRST(e) ∪{#}
={a,d}∪{a,d,c,e}∪{e}∪{#}
={a,c,d,e#}
②又因为A→BSD与D→ε,所以FOLLOW中还包含FOLLOW(A)。

因为S→aAbDe与B→SAc,所以
FOLLOW(A)=FIRST(bDe)∪FIRST(c)={b,c}
综合①、②得FOLLOW(S)={a,d,c,e,#}∪{a,b,c,d,e,#}
因为A→BSD,所以FOLLOW(B)=FIRST(SD)={a,d}
因为S→aAbDe | d、A→BSD| e与B→SAc | cD,所以
FOLLOW(D)=FIRST(e)∪FOLLOW(A)∪FOLLOW(B)
={e}∪{b,c}∪{a,d}={a,b,c,d,e}
(2)G[S]不就是LL(1)文法。

因为产生式B→SAc|cD| ε中
FIRST(SAc)∩FOLLOW(B)={a,d}≠Ø
(3)构造G[S]得LL(1)分析表。

按照LL(1)分析表得构造算法构造方法G[S]得LL(1)分析表如表4-3-2所示。

4解答:对文法G[V]提取公共左因子后得到文法:
G′[V]:V→NA
A→ε|[E]
E→VB
B→ε|+E
N→i
求出文法G′[V]中每一个非终结符号得FIRST集:
FIRST(V)={i} FIRST(A)={[,ε}
FIRST(E)={i} FIRST(B)={+,ε}
FIRST(N)={i}
求出文法G′[V]中每一个非终结符号得FOLLOW集:
FOLLOW(V)={#}∪FIRST(B)\{ε}∪FOLLOW(E)={#,+,]}
FOLLOW(A)= FOLLOW(V)={+,,#}
FOLLOW(E)= FIRST(])\{ε}∪FOLLOW(B)= FIRST(])\{ε}∪FOLLOW(E)={]}
FOLLOW(B)= FOLLOW(E)={ ]}
FOLLOW(N)= FIRST(A)\{ε}∪FOLLOW(V)={[,],+,#}
可以瞧到,对文法G′[V]得产生式A→ε|[E],有
FIRST([E])∩FOLLOW(A)={[}∩{+,],#}= Ø
对产生式B→ε|+E,有
FIRST(+E)∩FOLLOW(B)={+}∩{]}= Ø
而文法得其她产生式都只有一个不为ε得右部,所以文法G′[V]就是LL(1)文法。

5解答:(1)因为产生式A→aAa|ε有空产生式右部,而
FOLLOW(A)={#}∪FIRST(a)={a, #}
造成FIRST(A)∩FOLLOW(A)={A, ε}∩{a, #}≠Ø
所以该文法不就是LL(1)文法。

(2)若采用LL(1)方法进行语法分析,必须修改该文法。

因该文法产生偶数(可以为0)个a,所以得到文法
G′[A]:A→aaA|ε
此时对产生式A→aaA|ε,有FOLLOW(A)={#}∪FOLLOW(A)={#},因而
FIRST(A)∩FOLLOW(A)={a, ε}∩{#}=Ø
所以文法G′[A]就是LL(1)文法,按LL(1)分析表构造算法构造该文法得LL(1)分析表如表4-3-3所示。

表4-3-3 文法G′[A]得LL(1)分析表
(3)若采用LL(1)方法进行语法分析,对符号串“aaaa”得分析过程如表4-3-4所示。

表4-3-4 对符号串“aaaa”得分析过程
第五章
1、设有文法G[S]为:
S→a|b|(A)
A→SdA|S
(1)完成下列算符优先关系表,见表5-7-1,并判断G[S]就是否为算符优先文法。

表5-7-1 算符优先关系表
(2)给出句型(
(3)给出输入串(adb)#得分析过程。

解答:
(1)先求文法G[S]得FIRSTVT集与LASTVT集:
由S→a|b|(A)得:FIRSTVT(S)={a,b,( );
由A→Sd…得:FIRSTVT(A)={d};又由A→S…得:FIRSTVT(S) ⊂FIRSTVT(A),即FIRSTVT(A)={d,a,b,(};
由S→a|b|(A)得;LASTVT(S)={a,b,}};
由A→…dA得:LASTVT(A)={d},又由A→S得:LASTVT(S) ⊂LASTVT(A),即LASTVT(A)={d,a,b,)}。

构造优先关系表方法如下:
①对P→…ab…,或P→…aQb…,有a≖b;
②对P→…aR…,而b∈FIRSTVT(R),有a⋖b;
③对P→…Rb…,而a∈FIRSTVT(R),有a⋗b。

由此得到:
①由S→(A)得:(≖);
②由S→(A…得:(⋖FIRSTVT(A),即:(⋖d,(⋖a ,(⋖b,(⋖(;由A→…dA得:d⋖FIRSTVT(A),
即:d⋖d,d⋖a,d⋖b,d⋖(;
③由S→A)得,LASTVT(A)⋗),即:d⋗),a⋗),b⋗),)⋗);由A→Sd…得:LASTVT(S)⋗d,即:a⋗d,b⋗d,)⋗d;
此外,由#S#得:#≖#;
由#⋖FIRSTVT(S)得:#⋖a,#⋖b,#⋖(;脂由LASTVT(S)⋗#得:d⋗#,a⋗#,b⋗#,)⋗#。

最后得到算符优先关系表,见表5-7-2。

表5-7-2 算符优先关系表
由表5-7-2G[S]为算符优先文法。

(2)为求出句型(SdSdS)得短语、简单短语、句柄,我们先画出该句型对应得语法树,如图
第六章
一、单项选择题
1、若a为终结符,则A→α·aβ为项目
a、归约
b、移进
c、接受
d、待约
2、若项目集I k含有A→α·,则在状态k时,仅当面临得输入符号a∈FOLLOW(A)时,才采取“A →α·”动作得一定就是。

a、LALR文法
b、LR(0)文法
c、LR(1)文法
d、SLR(1)文法
3、就文法得描述能力来说,有。

a、SLR(1)⊂LR(0)
b、LR(1)⊂LR(0)
c、SLR(1)⊂LR(1)
d、无二义文法⊂LR(1)
4、在LR(0)得ACTION子表中,如果某一行中存在标记“r j”得栏,则。

a、该行必定填满r j
b、该行未填满r j
c、其她行也有r j
d、goto子表中也有r j
5、一个指明了在分析过程中得某时刻所能瞧到产生式多大一部分。

a、活前缀
b、前缀
c、项目
d、项目集
二、多项选择题
1、一个LR分析器包括。

a、一个总控程序
b、一个项目集
c、一个活前缀
d、一张分析表
e、一个分析栈
2、LR分析器核心部分就是一张分析表,该表包括等子表。

a、LL(1)分析
b、优先关系
c、GOTO
d、LR
e、ACTION
3、每一项ACTION[S,a]所规定得动作包括。

a、移进
b、比较
c、接受
d、归约
e、报错
4、对LR分析表得构造,有可能存在动作冲突。

a、移进
b、归约
c、移进/归约
d、移进/移进
e、归约/归约
5、就文法得描述能力来说,有。

a、SLR(1)⊂LR(1)
b、LR(1)⊂SLR(1)
c、LR(0)⊂LR(1)
d、LR(1)⊂无二义文法
e、SLR(1)⊂无二义文法
6、对LR分析器来说,存在等分析表得构造方法。

a、LALR
b、LR(0)
c、SLR(1)
d、SLR(0)
e、LR(1)
7、自上而下得语法分析方法有。

a、算符优先分析法
b、LL(1)分析法
c、SLR(1)分析法
d、LR(0)分析法
e、LALR(1)分析法
三、填空题
1、对于一个文法,如果能够构造。

使得它得均就是唯一确定得,则称该文法为LR文法。

2、字得前缀就是指该字得。

3、活前缀就是指得一个前缀,这种前缀不含之后得任何符号。

4、在LR分析过程中,只要得已扫描部分保持可归约成一个,则扫描过得部分正确。

5、将识别得NFA确定化,使其成为以为状态得DFA,这个DFA就就是建立得基础。

6、A→α·称为项目;对文法开始符S′→α·为项目;若a为终结符,则称A→α·aβ为项目;若B为非终结符,则称A→α·aβ为项目。

7、LR(0)分析法得名字中“L”表示,“R”表示,“0”表示。

四、综合题
1、对于文法G[S]:S→AS|b
A→SA|a
(1)列出所有LR(0)项目
(2)列出构成文法LR(0)项目集规范族。

单项解答:
1、A→α·称为归约项目,对文法开始符S′得归约项目,如S′→α·称为接受项目,A→α·aβ(a为终结符)称为移进项目。

在此选b、
2、当用产生式A→α归约时,LR(0)无论面临什么输入符号都进行归约;SLR(1)则仅当面临得输入符号a∈FOLLOW(A)时进行归约;LR(1)则当在把α归约为A得规范句型得前缀βAa 前提下,当α后跟终结符a时,才进行归约;因此选d。

3、由于LR(0)⊂SLR(1)⊂LR(1)⊂无二义文法,故选c。

4、选a。

5、选c。

多选解答:
1、一个LR分析器包括一个总控程序与一张分析表,选a、d。

2、选c、e。

3、选a、c、d、e。

4、在LR分析表得构造中有可能存在“移进”/“归约”与“归约”/“归约”冲突;故选c、e。

5、选a、b、c、d、e。

6、选a、b、c、e。

7、选a、c、d、e。

填空解答:
1、一张分析表每个入口
2、任意首部
3、规范句型句柄
4、输入串活前缀
5、活前缀项目集合LR分析算法
6、归约接受移进待约
7、自左至右分析采用最右推导得逆过程即最左归约向右查瞧0个字符
综合解答:
首先将文法G拓广为G[S′]:
S′→S
S→AS|b
A→SA|a
(1)文法G[S′]得LR(0)项目就是:
1、S′→·S 5、S→AS·9、A→S·A
2、S′→S·6、S→·b 10、A→SA·
3、S→·AS 7、S→b·11、A→·a
4、S→A·S 8、A→·SA 12、A→a·
2、列出构成文法LR(0)项目集规范族。

用ε-CLOSURE(闭包)办法构造文法G′得LR(0)项目集规范族如下:
I0:1、S′→·S I3: 9、A→S·A I6:12、A→a·
3、S→·AS 8、A→·SA I7:7、S→b·
8、A→·SA 3、S→·AS
11、A→·a 6、S→·b
6、S→·b 11、A→·a
I1:2、S′→S·I4:10、A→SA·
9、A→S·A 4、S→A·S
8、A→·SA 3、S→·AS
11、A→·a 6、S→·b
3、S→·AS 8、A→·SA
6、S→·b 11、A→·a
I2:4、S→A·S I5: 5、S→AS·
3、S→·AS 9、A→S·A
6、S→·b 8、A→·SA
8、A→·SA 11、A→·a
11、A→·a 3、S→·AS
6、S→·b
注意:I1中得S′→S·与A→·SA就是由状态I0中得1与3读入一个S字符后得到得下一个项目;,而I4中得A→SA与A→A·S则就是由I3中得9与3读入一个A字符后得到得下一个项目;I5中得S→AS·与A→S·A 则就是由I4中得4与8读入一个S字符后得到得下一个项目。

状态全体构成了文法G′得LR(0)规范族。

第七章
一、单项选择题
1、中间代码生成所依据得就是。

a、语法规则
b、词法规则
c、语义规则
d、等价变换规则
2、四元式之间得联系就是通过实现得。

a、指示器
b、临时变量
c、符号表
d、程序变量
3、后缀式ab+cd+/可用表达式来表示。

a、a+b/c+d
b、(a+b)/(c+d)
c、a+b/(c+d)
d、a+b+c/d
4、表达式(┓A∨B)∧(C∨D)得逆波兰表示为。

a、┓AB∨∧CD∨
b、A┓B∨CD∨∧
c、AB∨┓CD∨∧
d、A┓B∨∧CD∨
5
所对应得表达式为。

a、A+B+C+D
b、A+(B+C)+D
c、(A+B)+C+D
d、(A+B)+(C+D)
6、四元式表示法得优点为。

a、不便于优化处理,但便于表得更动
b、不便于优化处理,但节省存储空间
c、便于优化处理,也便于表得更动
d、便于表得更动,也节省存储空间
7、终结符具有属性。

a、传递
b、继承
c、抽象
d、综合
二、多顶选择题
1、中间代码主要有。

a.四元式b.二元式c.三元式d.后缀式e.间接三元式2、下面中间代码形式中,能正确表示算术表达式a+b+c得有。

a .ab+c+
b .abc++
c .
d .
e .a+b+c
3、在下面得 语法制导翻译中,采用拉链-回填技术。

a .赋值语句
b .goto 语句
c .条件语句
d .循环语句
4、下列 中间代码形式有益于优化处理。

a .三元式
b .四元式
c .间接三元式
d .逆波兰表示法
e .树形表示法
5、在编译程序中安排中间代码生成得目得就是 。

a .便于进行存储空间得组织
b .利于目标代码得优化
c .利于编译程序得移植
d .利于目标代码得移植
e .利于提高目标代码得质量 6、下面得中间代码形式中, 能正确表示算术表达式a .ab+c* b .abc*+ c .a+b*c 7、三地址代码语句具体实现通常有 表示方法。

a .逆波兰表示
b .三元式
c 三、填空题
1、中间代码有 等形式,生成中间代码主要就是为了使 。

2、语法制导翻译既可以用来产生 代码,也可以用来产生 指令,甚至可用来对输入串进行 。

3、当源程序中得标号出现“先引用后定义”时,中间代码得转移地址须持 时才能确定,因而要进行 。

4、文法符号得属性有两种,一种称为 ,另一种称为 。

5、后缀式abc-/所代表得表达式就是 ,表达式(a-b)*c 可用后缀式 表示。

6、用一张 辅以 得办法来表示中间代码,这种表示法称为间接三元式。

四、综合题
1、给出下列表达式得逆波兰表示(后缀式):
① a*(-b+c)
② (A ∨B)∧(C ∨┑D ∧E)
2、写出算术表达式:A+B*(C-D)+E/(C-D)↑N 得
①四元式序列;②三元式序列;③间接三元式序列
单选解答
1、选c 。

2、四元式之间得联系就是通过临时变量实现得,故选b 。

3、选b 。

4、选b 。

5、选d 。

6、四元式表示法得优点与间接三元式相同,故选c 。

7、选d 。

多选解答
1、选a 、c 、d 、e 。

2、b 、d 得中间代码不能正确表示a+b+c ,而e 不就是中间代码:故选a 、c 。

3、凡涉及到跳转得语句都需要采用拉链——回填技术,故选 b 、c 、d 。

4、选b 、c 。

5、选b 、d 。

6、选b 、e 。

7、选b 、c 、e 。

填空解答
1、逆波兰记号、树形表示、三元式、四元式 目标代码得优化容易实现
2、中间 目标 解释执行
3、标号定义 回填
4、继承属性 综合属性
5、a/(b-c) ab-c*
6、间接码表 三元式表
综合解答1、
① ab@c+*;
② AB ∨CD ┑E ∧∨∧ 2、 ①表达式得四元式序列: ②表达式得三元式序列 ③间接三元式序列
(1)(-,C,D,T 1) (1)(-,C,D) ⑴ (1)(-,C,D)
(2)(*,B,T 1,T 2) (2)(*,B,(1)) ⑵ (2)(*,B,(1))
(3)(+,A,T 2,T 3) (3)(+,A,(2)) ⑶ (3)(+,A,(2))
(4)(-,C,D,T ) (4)(-,C,D) ⑴ ⑷ (↑,(1),N)
第八章
一、单项选择题
1、编译程序使用区别标识符得作用域。

a、说明标识符得过程或函数名
b、说明标识符得过程或函数得静态层次
c、说明标识符得过程或函数得动态层次
d、标识符得行号
2、在目标代码生成阶段,符号表用于。

a、目标代码生成
b、语义检查
c、语法检查
d、地址分配
3、过程信息表不包含。

a、过程入口地址
b、过程得静态层次
c、过程名
d、过程参数信息
4、下列关于标识符与名字叙述中,正确得就是。

a、标识符有一定得含义
b、名字就是一个没有意义得字符序列
c、名字有确切得属性
d、a~c都不正确
二、多项选择题
1、符号表得每一项均包含。

a、名字栏
b、类型栏
c、信息栏
d、值栏
e、a~d均包含
2、对编译程序所用到得符号表,涉及得操作有。

a、填写或更新信息栏内容
b、填入新名
c、给定名字,访问它得有关信息
d、杂凑技术
e、线性表与排序二叉树
3、源程序中得错误一般有。

a、词法错误
b、语法错误
c、语义错误
d、编译错误
e、违反环境限制得错误
三、填空题
1、符号表中名字栏内容有两种填写方式,它们就是填写与填写。

2、词法分析阶段得错误主要就是,可通过得办法纠正错误。

3、符号表中名字得有关信息在与过程中陆续填入。

4、在目标代码生成阶段,符号表就是得依据。

四、问答题:
1、在编译过程中为什么要建立符号表?
单选解答:1、b 2、d 3、b 4、c
多选解答:1、a 、c 2、a、b、c 3、a、b、c、e
填空解答:1、标识符标识符地址及长度2、拼写错误最小距离匹配3、词法分析语法语义分析
4、地址分配
问答题解答:
在编译过程中始终要涉及到对一些语法符号得处理,这就需要用到语法符号得相关属性。

为了在需要时能找到这些语法成分及其相关属性,就必须使用一些表格来保存这些语法成分及其属性,这些表格就就是符号表。

第九章
一、单项选择题
1、程序所需得数据空间在程序运行前可确定,称为管理技术。

a、动态存储
b、栈式存储
c、静态存储
d、堆式存储
2、堆式动态分配申请与释放存储空间遵守原则。

a、先请先放
b、先请后放
c、后请先放
d、任意
3、静态分配允许程序出现。

a、递归过程
b、可变体积得数据项目
c、静态变量
d、待定性质得名字
4、在编译方法中,动态存储分配得含义就是。

a、在运行阶段对源程序中得数组、变量、参数等进行分配
b、在编译阶段对源程序中得数组、变量、参数进行分配
c、在编译阶段对源程序中得数组、变量、参数等进行分配,在运行时这些数组、变量、参
数得地址可根据需要改变
d、以上都不正确
5、在编译时有传名功能得高级程序语言就是。

a、Fortran
b、Basic
c、Pascal
d、ALGOL
6、栈式动态分配与管理在过程返回时应做得工作有。

a、保护SP
b、恢复SP
c、保护TOP
d、恢复TOP
二、多项选择题
1、下面需要在运行阶段分配存储空间。

a、数组
b、指针变量
c、动态数组
d、静态变量
e、动态变量
2、栈式动态分配允许。

a、递归过程
b、分程序结构
c、动态变量
d、动态数组
e、静态数组
3、动态存储分配可采用得分配方案有。

a、队式存储分配
b、栈式存储分配
c、链式存储分配
d、堆式存储分配
e、线性存储分配
4、栈式动态分配与管理因调用而进入过程之后,要做得工作就是。

a、定义新得活动记录得SP
b、保护返回地址
c、传递参数值
d、建立DISPLAY表
e、定义新得活动记录得TOP
5、静态分配不允许程序出现。

a、递归过程
b、静态数组
c、可变体积得数据项目
d、待定性质得名字
e、静态变量
6、活动记录包括。

a、局部变量
b、连接数据
c、形式单元
d、局部数组得内情变量
e、临时工作单元
三、填空题
1、FORTRAN语言采用了存储空间分配方案,其程序所需得存储空间在时确定。

2、一个函数得活动记录体积在时确定,数组内情向量表得体积在时确定,
3、目标程序运行得动态分配策略中,含有与分配策略
4、在Pascal中,由于允许用户动态地申请与释放内存空间,所以必须采用存储分配技术。

5、如果两个临时变量名不相交,则它们可分配在同一单元中。

6、堆式动态分配策略允许用户动态得与存储空间。

单选解答1、c 2、d 3、c 4、a 5、d 6、b
多选解答1、c e 2、a b d e 3、b d 4、abde5、acd6、abcde
填空解答
1、静态编译2、编译编译3、栈式堆式4、堆式5、作用域
6、申请释放
第十章
一、单项选择题
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.有多个入口语句与多个出口语句。

相关文档
最新文档