当前位置:文档之家› 编译原理期末复习题(含答案)(20页)

编译原理期末复习题(含答案)(20页)

编译原理期末复习题(含答案)(20页)
编译原理期末复习题(含答案)(20页)

第八节习题一、单项选择题

1、将编译程序分成若干个“遍”是为了 B 。

a.提高程序的执行效率

b.使程序的结构更加清晰

c.利用有限的机器内存并提高机器的执行效率

d.利用有限的机器内存但降低了机器的执行效率

2、构造编译程序应掌握D 。

a.源程序b.目标语言

c.编译方法d.以上三项都是

3、变量应当 C 。

a.持有左值b.持有右值

c.既持有左值又持有右值d.既不持有左值也不持有右值

4、编译程序绝大多数时间花在D上。

a.出错处理b.词法分析

c.目标代码生成d.管理表格

5、D不可能是目标代码。

a.汇编指令代码b.可重定位指令代码

c.绝对指令代码d.中间代码

6、使用 A 可以定义一个程序的意义。

a.语义规则b.词法规则

c.产生规则d.词法规则

7、词法分析器的输入是 B 。

a.单词符号串b.源程序

c.语法单位d.目标程序

8、中间代码生成时所遵循的是- C 。

a.语法规则b.词法规则

c.语义规则d.等价变换规则

9、编译程序是对 D 。

a.汇编程序的翻译b.高级语言程序的解释执行

c.机器语言的执行d.高级语言的翻译

10、语法分析应遵循 C 。

a.语义规则b.语法规则

c.构词规则d.等价变换规则

解答

1、将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选b。

2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选d。

3、对编译而言,变量既持有左值又持有右值,故选c。

4、编译程序打交道最多的就是各种表格,因此选d。

5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,因此不是目标代码的只能选d。

6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。因此选a。

7、b 8、c 9、d 10、c

二、多项选择题

1、编译程序各阶段的工作都涉及到BC 。

a.语法分析b.表格管理c.出错处理

d.语义分析e.词法分析

2、编译程序工作时,通常有ABCE 阶段。

a.词法分析b.语法分析c.中间代码生成

d.语义检查e.目标代码生成

解答

1.b、c 2. a、b、c、e

三、填空题

1、解释程序和编译程序的区别在于是否生成目标程序。

2、编译过程通常可分为5个阶段,分别是词法分析、语法分析中间代码生成、代码优化和目标代码生成。

3、编译程序工作过程中,第一段输入是源程序,最后阶段的输出为目标代码生成程序。

4、编译程序是指将高级语言程序翻译成低级语言程序的程序。

解答

是否生成目标程序2、词法分析中间代码生成3、源程序目标代码生成4、源程序目

标语言

一、单项选择题

1、文法G:S→xSx|y所识别的语言是 C 。

a. xyx

b. (xyx)*

c. x n yx n(n≥0)

d. x*yx*

2、文法G描述的语言L(G)是指 A 。

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、有限状态自动机能识别 C 。

a. 上下文无关文法

b. 上下文有关文法

c.正规文法

d. 短语文法

4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立C 。

a. 若f(a)>g(b),则a>b

b.若f(a)

c. a~b都不一定成立

d. a~b一定成立

5、如果文法G是无二义的,则它的任何句子α A 。

a. 最左推导和最右推导对应的语法树必定相同

b. 最左推导和最右推导对应的语法树可能不同

c. 最左推导和最右推导必定相同

d. 可能存在两个不同的最左推导,但它们对应的语法树相同

6、由文法的开始符经0步或多步推导产生的文法符号序列是 C 。

a. 短语

b.句柄

c. 句型

d. 句子

7、文法G:E→E+T|T

T→T*P|P

P→(E)|I

则句型P+T+i的句柄和最左素短语为 B 。

a.P+T和i

b. P和P+T

c. i和P+T+i

d.P和T

8、设文法为:S→SA|A

A→a|b

则对句子aba,下面 D 是规范推导。

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) C 。

a. {b,∧,(}

b. {b,∧,)}

c.{b,∧,(,,}

d.{b,∧,),,}

10、产生正则语言的文法为 D 。

a. 0型

b. 1型

c. 2型

d. 3型

11、采用自上而下分析,必须 C 。

a. 消除左递归

b. 消除右递归

c. 消除回溯

d. 提取公共左因子

12、在规范归约中,用 B 来刻画可归约串。

a. 直接短语

b. 句柄

c. 最左素短语

d. 素短语

13、有文法G:E→E*T|T

T→T+i|i

句子1+2*8+6按该文法G归约,其值为 B 。

a. 23 B. 42 c. 30 d. 17

14、规范归约指B 。

a. 最左推导的逆过程

b. 最右推导的逆过程

c. 规范推导

d. 最左归约的逆过程

[解答]

1、选c。

2、选a。

3、选c。

4、虽然a与b没有优先关系,但构造优先函数后,a与b就一定存在优先关系了。所以,由f(a)>g)(b)或f(a)

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

6、选c。

7、由图2-8-1的语法树和优先关系可以看出应选b。

E

E + F

E + T P

T i

P

#<·+·>+<·i·>#

图2-8-1 句型P+T+I的语法及优先关系

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

9、由T→T,…和T→(…得FIRSTVT(T))={(,,)};

由T→S得FIRSTVT(S)?FIRSTVT(T),而FIRSTVT(S)={b,∧,(};即

FIRSTVT(T)={b,∧,(,,};因此选c。

10、d 11、c 12、b 13、b 14、b

二、多项选择题

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、e、a、c 2、a、c、e 3、b、c、d 4、a、c 5、b、c 6、a、b、c、d、e

三、填空题

1、文法中的终结符和非终结符的交集是。词法分析器交给语法分析器的文法符号一定是,它一定只出现在产生式的部。

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

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

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

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

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

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

解答1、空集终结符右

2、最左

3、自上而上自下而上

4、自上而上

5、语法分析

6、移进接受

7、4 2 型3型上下文无关语言正规语言下推自动机有限

四、判断题

1、文法S→aS|bR|ε描述的语言是(a|bc)* ( )

R→c S

2、在自下而上的语法分析中,语法树与分析树一定相同。()

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

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

5、规范归约和规范推导是互逆的两个过程。()

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

解答1、对2、错3、错4、错5、错6、错

五、简答题

1、句柄

2、素短语

3、语法树

4、归约

5、推导

[解答]

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、文法G[S]:

S→aSPQ|abQ

QP→PQ

bP→bb

bQ→bc

cQ→cc

(1)它是Chomsky哪一型文法?

(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、按指定类型,给出语言的文法。

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

【解答】

(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、有文法G:S→aAcB|Bd

A→AaB|c

B→bScA|b

(1)试求句型aAaBcbbdcc和aAcbBdcc的句柄;

(2)写出句子acabcbbdcc的最左推导过程。

【解答】(1)分别画出对应两句型的语法树,如图2-8-2所示

句柄:AaB Bd

S

a A c B

A a

B b S c A

B d c

b

(a)

S

a A c B

B S c A

B d c

(b)

S

( L ) L , S

S ( L )

S a

图2-8-3 句型(S,(a ))的语法树 T

T * F

F ↑ P

P ( T )

T * F

图2-8-4 句型T*P ↑(T*F )的语法树

图2-8-2 语法树

(2)句子acabcbbdcc 的最左推导如下:

S ?aAcB ?aAaBcB ?acaBcB ?acabcB ?acabcbScA ?acabcbBdcA ?acabcbbdcA ?acabcbbdcc 5、对于文法G[S]:

S →(L )|aS|a L →L, S|S (1)画出句型(S,(a ))的语法树。(2)写出上述句型的所有短语、直接短语、句柄和素短语。 【解答】 (1)句型(S,(a ))的语法树如图2-8-3所示

(2)由图2-8-3可知:

①短语:S 、a 、(a)、S,(a)、(S,(a));

②直接短语:a 、S ; ③句柄:S ;

④素短语:素短语可由图2-8-3中相邻终结符之间的优先关系求得,即;

因此素短语为a 。

6、考虑文法G[T]: T →T*F|F F →F ↑P|P P →(T )|i

证明T*P ↑(T*F )是该文法的一个句型,并指出直接短语和句柄。 【解答】 首先构造T*P ↑(T*F )的语法树如图2-8-4所示。

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

一、单项选择题

1、词法分析所依据的是 。

a. 语义规则

b. 构词规则

c. 语法规则

d. 等价变换规则 2、词法分析器的输出结果是 。

a. 单词的种别编码

b. 单词在符号表中的位置

c. 单词的种别编码和自身值

d. 单词自身值 3、正规式M 1和M 2等价是指 。

# ·(·, ·( ·a · )· )· #

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开头的二进制数组成的集合

b. 以0结尾的二进制数组成的集合

c. 含奇数个0的二进制数组成的集合

d. 含偶数个0的二进制数组成的集合 5、词法分析器作为独立的阶段使整个编译程序结构更加简洁、明确,因此, 。 a. 词法分析器应作为独立的一遍 b. 词法分析器作为子程序较好

c. 词法分析器分解为多个过程,由语法分析器选择使用

d. 词法分析器并不作为一个独立的阶段 解答 1、b 2、c 3、c 4、d 5、b 二、多项选择题

1、在词法分析中,能识别出 ACE 。 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、a 、

c 、e 2、a 、b 、

d 三、填空题

1、确定有限自动机DFA 是 NFA 的一个特例。

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

3、一个字集是正规的,当且仅当它可由 DFA(NFA) 所 识别 。 解答 1、NFA 2、正规集 3、DFA (NFA )所识别 四、判断题

1、一个有限状态自动机中,有且仅有一个唯一终态。 ( F )

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

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

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

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

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

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

8、对任何正规表达式e ,都存在一个DFA M ,满足L(G)=L(e)。 ( T ) 解答 1 、2、3、错 4、5、6、7、8、正确 五、基本题

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 ′。

解答:对照自动机的定义M=(S,Σ,f,S 0,Z),由f 的定义可知f(x,a)、f(y,b)均为多值函数,所以是一非确定有限自动机,先画出NFA M 相应的状态图,如图3-6-2所示。

用子集法构造状态转换矩阵表3-6-3所示。

I I a I b {x} {x,y} {y} {y}

{x,y}

a a

b b b

图3-6-2 NFA M X Y

0 1 0 图3-6-1 Y X

a a,

b b b

图3-6-5 DFA M ′

0 2 1

a

a d ε

ε

b * b *(d|ad)(b|ab)(b|ab)* X Y

X 1 2 3 Y X 4 1 3 5 Y

6 7 8

(d|ad) (b|ab) (b|ab)* 2

ε d

b

ad ab ε ε

b|ab

b

X 4 1 3 5

Y 2 b

ε

d

b ε ε b

a b

b

图3-6-7 的NFA M

{x,y} {x,y} {x,y}

将转换矩阵中的所有子集重新命名而形成表3-6-4所示的状态转换矩阵。 表3-6-4 状态转换矩阵

a b 0 2 1 1 — 2 2

2

2

即得到M ′=({0,1,2}, {a,b}, f,0, {1,2}),其状态转换图如图3-6-5所示。

将图3-6-5的DFA M ′最小化。首先,将M ′的状态分成终态组{1,2}与非终态组{0};其次,考察{1,2}。由于{1,2}a={1,2}b={2}?{1,2},所以不再将其划分了,也即整个划分只有两组{0},{1,2}:令状态1代表{1,2},即把原来到达2的弧都导向1,并删除状态2。最后,得到如图3-6-6所示化简DFA M ′。

2、对给定正规式b*(d|ad )(b|ab )+,构造其NFA M ; 解答:首先用A +=AA *改造正规式得:b *(d|ad)(b|ab)(b|ab)*;其次,构造该正规式的NFA M ,如图3-6-7所示。

a

a,b

b

图3-6-6 化简后的DFA M ′

1

1、构造下面文法的LL(1)分析表。

D→ TL

T→ int | real

L→ id R

R→, id R | ε

解答: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)分析表

非终结符输入符号

int real id ,#

D D→TL D→TL

T T→int T→real

L L→id R

R R→,id R R→ε

2、下面文法G[S]是否为LL(1)文法?说明理由。

S →A B | P Q x A →x y B →b c

P →d P | εQ →a Q | ε

解答:该文法不是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、设有以下文法:

G[S]:S→aAbDe|d

A→BSD|e

B→SAc| cD| ε

D→Se| ε

(1)求出该文法的每一个非终结符U的FOLLOW集。

(2)该文法是LL(1)文法吗?

(3)构造C[S]的LL(1)分析表。

解答:(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-3-2 G[S]的LL(1)分析表

a b c d e #

S aAbDe d

A BSD BSD BSD e

B Sac/εcD Sac/ε

D Se/εεεSe/εε

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

G[V]:V→N|N[E]

E→V|V+E

N→i

解答:对文法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、已知文法:

G[A]:A→aAa|ε

(1)该文法是LL(1)文法吗?为什么?

(2)若采用LL(1)方法进行语法分析,如何得到该文法的LL(1)分析表?

(3)若输入符号串“aaaa”,请给出语法分析过程。

解答:(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)分析表

A #

A A→aaA A→ε

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

表4-3-4 对符号串“aaaa”的分析过程

步骤分析栈输入串产生式/动作

1 #A a a a a # A→aaA

2 #A a a a a a a # 匹配

3 #A a a a a # 匹配

4 #A a a # A→aaA

5 #A a a a a # 匹配

6 #A a a# 匹配

7 #A # A→ε

8 # # 接受

第七节习题

设有文法G[S]为:

S→a|b|(A)

A→SdA|S

(1)完成下列算符优先关系表,见表5-7-1,并判断G[S]是否为算符优先文法。

表5-7-1 算符优先关系表

a b ( ) d # a ? ? b ? ? ( ? ? ? ? ) ? ? d #

?

?

?

?

(2)给出句型(SdSdS )的短语、简单短语、句柄、素短语和最左素短语。 (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 算符优先关系表

a b ( ) d # a ? ? ? b ? ? ? ( ? ? ? ? ) ? ? ? d ? ? ? ? ? ? #

?

?

?

?

由表5-7-2可以看出,任何两个终结符之间至少只满足?、?、?三种优先关系之一,故G[S]为算符优先文法。

(2)为求出句型(SdSdS )的短语、简单短语、句柄,我们先画出该句型对应的语法树,如图5-7-3所示。由图5-7-3得到: 短语:S ,SdS ,SdSdS ,(SdSdS )

简单短语(即直接短语):S 句柄(即最左直接短语):S

素短语:SdS ,它同时也是该句型的最左素短语。

S

A S

A S d ( )

A S

d

(3)输入串(adb)#的分析过程见表5-7-4

表5-7-4 输入串(adb)#的分析过程

符号栈输入串说明

# (adb)# 移进

#(adb)# 移进

#(a db)# 用S→a归约

#(S db)# 移进

#(Sd b)# 移进

#(Sdb )# 用S→b归约

#(SdS )# 用A→S归约

#(SdA )# 用A→SdA归约

#(A )# 移进

#(A)# 用S→(A)归约#S # 分析成功

第四节习题

一、单项选择题

1、若a为终结符,则A→α·aβ为 B 项目

a.归约

b.移进

c.接受

d.待约

2、若项目集I k含有A→α·,则在状态k时,仅当面临的输入符号a∈FOLLOW(A)时,才采取“A →α·”动作的一定是。

https://www.doczj.com/doc/7a13467077.html,LR文法

b.LR(0)文法

c.LR(1)文法

d.SLR(1)文法

3、就文法的描述能力来说,有 C 。

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、一个 C 指明了在分析过程中的某时刻所能看到产生式多大一部分。

a.活前缀

b.前缀

c.项目

d.项目集

解答:

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分析器包括AD。

a.一个总控程序

b.一个项目集

c.一个活前缀

d.一张分析表

e.一个分析栈

2、LR分析器核心部分是一张分析表,该表包括CE 等子表。

a.LL(1)分析

b.优先关系

c.GOTO

d.LR

e.ACTION

3、每一项ACTION[S,a]所规定的动作包括ACDE 。

a.移进

b.比较

c.接受

d.归约

e.报错

4、对LR分析表的构造,有可能存在CE 动作冲突。

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分析器来说,存在ABCE 等分析表的构造方法。

https://www.doczj.com/doc/7a13467077.html,LR

b.LR(0)

c.SLR(1)

d.SLR(0)

e.LR(1)

7、自上而下的语法分析方法有ACDE 。

a.算符优先分析法

b.LL(1)分析法

c.SLR(1)分析法

d.LR(0)分析法

https://www.doczj.com/doc/7a13467077.html,LR(1)分析法

解答:

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、对于一个文法,如果能够构造一张分析表。使得它的每个入口均是唯一确定的,则称该文法为LR文法。

2、字的前缀是指该字的任意首部。

3、活前缀是指规范句型的一个前缀,这种前缀不含句柄之后的任何符号。

4、在LR分析过程中,只要输入串的已扫描部分保持可归约成一个活前缀,则扫描过的部分正确。

5、将识别活前缀的NFA确定化,使其成为以项目集合为状态的DFA,这个DFA就是建立LR分析法的基础。

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

7、LR(0)分析法的名字中“L”表示自左至右分析,“R”表示采用最右推导的逆过程即最左归约,“0”表示向右查看0个字符。

解答:

1、一张分析表每个入口

2、任意首部

3、规范句型句柄

4、输入串活前缀

5、活前缀项目集合LR分析算法

6、归约接受移进待约

7、自左至右分析采用最右推导的逆过程即最左归约向右查看0个字符

四、综合题

1、对于文法G[S]:S→AS|b

A→SA|a

(1)列出所有LR(0)项目

(2)列出构成文法LR(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)项目集规范族如下:

I 0:1、S′→·S I 3: 9、A →S ·A I 6:12、A →a · 3、S →·AS 8、A →·SA I 7:7、S →b · 8、A →·SA 3、S →·AS 11、A →·a 6、S →·b 6、S →·b 11、A →·a

I 1:2、S′→S · I 4: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 I 2:4、S →A ·S I 5: 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

注意:I 1中的S′→S ·和A →·SA 是由状态I 0中的1和3读入一个S 字符后得到的下一个项目;,而I 4中的A →SA 和A →A ·S 则是由I 3中的9和3读入一个A 字符后得到的下一个项目;I 5中的S →AS ·和A →S ·A 则是由I 4中的4和8读入一个S 字符后得到的下一个项目。

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

第八节 习题

一、单项选择题

1、中间代码生成所依据的是 C 。 a.语法规则 b.词法规则 c.语义规则 d.等价变换规则

2、四元式之间的联系是通过 B 实现的。 a.指示器 b.临时变量 c.符号表 d.程序变量

3、后缀式ab+cd+/可用表达式 B 来表示。 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、中间代码的树型表示 所对应的表达式为 D 。 a.A+B+C+D b.A+(B+C)+D c.(A+B)+C+D d.(A+B)+(C+D)

6、四元式表示法的优点为 C 。

a.不便于优化处理,但便于表的更动

b.不便于优化处理,但节省存储空间

c.便于优化处理,也便于表的更动

d.便于表的更动,也节省存储空间 7、终结符具有 综合 属性。 a.传递 b.继承 c.抽象 d.综合

解答

1、选c 。

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

3、选b 。

4、选b 。

5、选d 。

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

7、选d 。 二、多顶选择题

+ +

A

B

C

D +

+ + c a b

+

a +

b c

*

+ c

+

a *

1、中间代码主要有ACDE 。

a.四元式b.二元式c.三元式d.后缀式e.间接三元式

2、下面中间代码形式中,能正确表示算术表达式a+b+c的有AC 。

a.ab+c+ b.abc++ c.d.e.a+b+c

3、在下面的BCD 语法制导翻译中,采用拉链-回填技术。

a.赋值语句b.goto语句c.条件语句d.循环语句

4、下列BC 中间代码形式有益于优化处理。

a.三元式b.四元式c.间接三元式d.逆波兰表示法e.树形表示法

5、在编译程序中安排中间代码生成的目的是BD 。

a.便于进行存储空间的组织b.利于目标代码的优化

c.利于编译程序的移植d.利于目标代码的移植

e.利于提高目标代码的质量

6、下面的中间代码形式中,BE 能正确表示算术表达式a+b*c。题)

a.ab+c* b.abc*+ c.a+b*c d.e.

7、三地址代码语句具体实现通常有BCE 表示方法。

a.逆波兰表示b.三元式c.间接三元式d.树形表示e.四元式

解答

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、后缀式abc-/所代表的表达式是a/(b-c) ,表达式(a-b)*c可用后缀式ab-c* 表示。

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

解答

1、逆波兰记号、树形表示、三元式、四元式目标代码的优化容易实现

2、中间目标解释执行

3、标号定义回填

4、继承属性综合属性

5、a/(b-c) ab-c*

6、间接码表三元式表

四、综合题

1、给出下列表达式的逆波兰表示(后缀式):

①a*(-b+c)

②(A∨B)∧(C∨┑D∧E)

2、写出算术表达式:A+B*(C-D)+E/(C-D)↑N的

①四元式序列;②三元式序列;③间接三元式序列

解答1、

①ab@c+*;

②AB∨CD┑E∧∨∧

2、

①表达式的四元式序列:②表达式的三元式序列③间接三元式序列

(1)(-,C,D,T1) (1)(-,C,D) ⑴(1)(-,C,D)

(2)(*,B,T1,T2) (2)(*,B,(1)) ⑵(2)(*,B,(1))

(3)(+,A,T2,T3) (3)(+,A,(2)) ⑶(3)(+,A,(2))

(4)(-,C,D,T4) (4)(-,C,D) ⑴⑷(↑,(1),N)

(5)(↑,T4,N,T5) (5)(↑,(4),N) ⑷⑸(/,E,(4))

⑹(/,E,T5,T6) ⑹(/,E,(5)) ⑸⑹(+,(3),(5))

⑺(+,T3,T6,T7) ⑺(+,(3),(6))⑹

第三节习题

一、单项选择题

1、编译程序使用 B 区别标识符的作用域。

a. 说明标识符的过程或函数名

b. 说明标识符的过程或函数的静态层次

c. 说明标识符的过程或函数的动态层次

d. 标识符的行号

2、在目标代码生成阶段,符号表用于 D 。

a. 目标代码生成

b. 语义检查

c. 语法检查

d. 地址分配

3、过程信息表不包含 B 。

a. 过程入口地址

b. 过程的静态层次

c. 过程名

d. 过程参数信息

4、下列关于标识符和名字叙述中,正确的是 C 。

a. 标识符有一定的含义

b. 名字是一个没有意义的字符序列

c. 名字有确切的属性

d. a~c都不正确

解答:1、b 2、d 3、b 4、c

二、多项选择题

1、符号表的每一项均包含AC 。

a. 名字栏

b. 类型栏

c. 信息栏

d. 值栏

e. a~d均包含

2、对编译程序所用到的符号表,涉及的操作有ABC 。

a. 填写或更新信息栏内容

b. 填入新名

c.给定名字,访问它的有关信息

d. 杂凑技术

e.线性表和排序二叉树

3、源程序中的错误一般有ABCE 。

a. 词法错误

b. 语法错误

c. 语义错误

d. 编译错误

e. 违反环境限制的错误

解答:1、a 、c 2、a、b、c 3、a、b、c、e

三、填空题

1、符号表中名字栏内容有两种填写方式,它们是填写和填写。

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

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

4、在目标代码生成阶段,符号表是地址分配的依据。

解答:1、标识符标识符地址及长度2、拼写错误最小距离匹配3、词法分析语法语义分析

4、地址分配

四、问答题:

1、在编译过程中为什么要建立符号表?

解答:

在编译过程中始终要涉及到对一些语法符号的处理,这就需要用到语法符号的相关属性。为了在需要时能找到这些语法成分及其相关属性,就必须使用一些表格来保存这些语法成分及其属性,这些表格就是符号表。

第四节习题

一、单项选择题

1、程序所需的数据空间在程序运行前可确定,称为 C 管理技术。

a. 动态存储

b. 栈式存储

c. 静态存储

d. 堆式存储

2、堆式动态分配申请和释放存储空间遵守 D 原则。

a. 先请先放

b. 先请后放

c. 后请先放

d. 任意

3、静态分配允许程序出现 C 。

a. 递归过程

b. 可变体积的数据项目

c. 静态变量

d. 待定性质的名字

4、在编译方法中,动态存储分配的含义是 A 。

a. 在运行阶段对源程序中的数组、变量、参数等进行分配

b. 在编译阶段对源程序中的数组、变量、参数进行分配

c. 在编译阶段对源程序中的数组、变量、参数等进行分配,在运行时这些数组、变量、参

数的地址可根据需要改变

d. 以上都不正确

5、在编译时有传名功能的高级程序语言是 D 。

a. Fortran

b. Basic

c. Pascal

d. ALGOL

6、栈式动态分配与管理在过程返回时应做的工作有 B 。

a. 保护SP

b. 恢复SP

c.保护TOP

d. 恢复TOP

解答1、c 2、d 3、c 4、a 5、d 6、b

二、多项选择题

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、c e 2、a b d e 3、b d 4、abde5、acd6、abcde

三、填空题

1、FORTRAN语言采用了静态存储空间分配方案,其程序所需的存储空间在编译时确定。

2、一个函数的活动记录体积在编译时确定,数组内情向量表的体积在编译时确定,

3、目标程序运行的动态分配策略中,含有栈式和堆式分配策略

4、在Pascal中,由于允许用户动态地申请与释放内存空间,所以必须采用堆式存储分配技术。

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

6、堆式动态分配策略允许用户动态的申请和释放存储空间。

解答

1、静态编译2、编译编译3、栈式堆式4、堆式5、作用域

6、申请释放

第五节习题

一、单项选择题

1、优化可生成 D 的目标代码。

a.运行时间较短b.占用存储空间较小

c.运行时间短但占用内存空间大d.运行时间短且占用存储空间小

2、下列C 优化方法不是针对循优化进行的。

a.强度削弱b.删除归纳变量c.删除多余运算d.代码外提

3、基本块内的优化为B 。

a.代码外提,删除归纳变量b.删除多余运算,删除无用赋值

c.强度削弱,代码外提d.循环展开,循环合并

4、关于必经结点的二元关系,下列叙述中不正确的是。

a.满足自反性b.满足传递性c.满足反对称性d.满足对称性

5、对一个基本块来说, A 是正确的。

a.只有一个入口语句和一个出口语句b.有一个入口语句和多个出口语句

c.有多个入口语句和一个出口语句d.有多个入口语句和多个出口语句

6、在程序流图中,我们称具有下述性质D 的结点序列为一个循环。

a.它们是非连通的且只有一个入口结点b.它们是强连通的但有多个入口结点

c.它们是非连通的但有多个入口结点d.它们是强连通的且只有一个入口结点

7、D 不可能是目标代码。

a.汇编指令代码b.可重定位指令代码c.绝对指令代码d.中间代码[解答]

1、优化的目的是使目标程序运行时间短、占用存储空间小,故选d。

2、删除多余运算属基本块优化,故选c。

3、基本块优化包括:合并已知量、删除无用赋值及删除多余运算,故选b。

4、必经结点满足自反性、传递性和反对称性关系,故选d。

5、选a。

6、选d。

7、选d。

二、多项选择题

1、根据优化所涉及的范围,可将优化分为ACD 。

a.局部优化b.过程优化c.全局优化

d.循环优化e.四元式优化

2、下列优化中,属于循环优化的有ABE 。

a.强度削弱b.合并已知量c.删除无用赋值

d.删除归纳变量e.代码外提

3、如果a→b是程序流图中的一条边,则由这条回边构成的循环由结点组成。

a.a b.b c.有通路到达b的结点

d.有通路到达a且该通路上不经过b的结点

e.有通路到达b且该通路上不经过a的结点

4、采用无环有向图(DAG),可以实现的优化有。

a.合并已知量b.删除公共子表达式c.强度削弱

d.删除无用赋值e.删除归纳变量

5、编译程序的输出结果可以是BCDE 。

a.目标代码b.汇编语言代码c.中间代码

d.优化后的中间代码e.可重定位代码

[解答]

1、选a、c、d。

2、循环优化包括:代码外提、强度削弱、删除归纳变量、循环展开和循环合并,故选a、b、e。

3、如果a→b是回边,则该回边的构成的循环由结点a、b和能够到达a但通路不经过b的结点组成;故选a、b、d。

4、DAG图可进行基本块范围内的优化,故选a、b、d。

5、选b、c、d、e。

三、填空题

1、局部优化是基本块范围内进行的一种优化。

2、在一个基本块内,可实行3种优化方法,即合并已知量、删除无用赋值、删除多余运算。

3、优化就是对程序进行各种等价变换,使之能生成更有效的目标代码。

4、在优化中,可把循环中的不变运算提到循环外面去,这种方法称为代码外提

[解答]

1、基本块

2、删除无用赋值删除多余运算

3、等价目标代码

4、不变运算代码外提

编译原理期末考试习题及答案

一、填空题|(每题4分,共20分) 1. 乔母斯基定义的3型文法(线性文法)产生式形式 A→Ba|a,或A→aB|a,A,B∈Vn, a,b∈Vt 。 2.语法分析程序的输入是单词符号,其输出是语法单位。 3 型为 B → .aB 的LR(0)项目被称为移进项目,型为 B → a.B 的LR(0) 项目被称为待约项目, 4.在属性文法中文法符号的两种属性分别为继承属性和综合属性。 5、运行时存贮管理方案有静态存储分配、动态存储分配和堆式存储分配和方案。 二.已知文法 G(S) (1) E → T | E+T (2) T → F | F*F (3) F →(E)| i (1)写出句型(T*F+i)的最右推到并画出语法树。(4分) (2)写出上述句型的短语,直接短语和句柄。(4分) 答:(1)最右推到(2分) E ==> T ==> F ==> (E) ==> (E+T) ==> (E+F) ==> (E+i) ==> (T+i) ==> (T*F+i) (2) 语法树(2分) (3)(4分) 短语:(T*F+i),T*F+i ,T*F , i 直接短语:T*F , i 句柄:T*F 三. 证明文法G(S) :S → SaS |ε是二义的。(6分) 答:句子aaa对应的两颗语法树为:

因此,文法是二义文法 四.给定正规文法G(S): (1) S → Sa | Ab |b (2) A → Sa 请构造与之等价的DFA。(6分) 答:对应的NFA为:(6分) 状态转换表: a b {F} Φ{S} {S} {S,A} Φ {S,A} {S,A} {S} 五. 构造识别正规语言b*a(bb*a)*b* 最小的DFA(要求写出求解过程)。(15分)答:(1)对应的NFA(5分) a b {0} {1,3} {0} {1,3} Φ{2,3} {2,3} {1,3} {2,3} (5分) 六. 已知文法G(S) : (1) S → ^ | a | (T) (2) T → T,S | S 试:(1)消除文法的左递归;(4分) (2)构造相应的first 和 follow 集合。(6分) 答:(1)消除文法的左递归后文法 G’(S)为: (1) S → ^ | a | (T)

全套编译原理复习与期末必考试题

第一章: 1.编译程序的步骤和任务: 1)词法分析:从左到右一个字符一个字符地读入源程序,对构成源程序的字符流进行扫描和分解,从而识别出一个个单词。 2)语法分析:是在词法分析基础上将单词序列分解成各类语法短语(比如程序、语句、表达式等),通过语法分析确定整个输入串是否构成一个语法上正确的程序。 3)语义分析:是审查源程序有无语义错误,为代码生成阶段收集类型信息。 4)中间代码产生:将源程序变成一种易于翻译成目标代码的内部表示形式。 5)代码优化:对前阶段生成的中间代码进行变换或改造,使生成的目标代码更为高效6)目标代码生成:把中间代码变换成特定机器上的绝对指令代码或可重定位的指令代码或汇编指令代码。 2.前端和后端的概念,试问前端通常包括那些阶段,后端包括那些阶段? 答:前端只依赖于源语言,与目标机无关。编译程序的前端通常包括词法分析程序、语法分析程序、语义分析程序、中间代码生成程序及相关的表格管理程序和出错处理程序。后端是指编译器中依赖于目标机器的部分,只与中间代码有关。通常包括目标代码生成程序、代码优化程序以及相关的表格管理程序和出错处理程序。 遍(PASS):对输入文件(源程序或其等价的中间语言程序)从头到尾扫视,完成预定处理的过程。 一个多遍的编译程序较之一遍的编译程序可能少占内存,逻辑结构可能清晰些,但效率相对可能差点 3.程序的正确与否:结构上的语法规则,语义上的语义规则。 翻译程序:汇编,解释,编译。 4.解释程序及其与编译程序的比较 解释程序功能:源程序+初始数据=计算结果 解释与编译的区别: 工作模式:这是根本区别,编译把源程序翻译成目标代码,而解释直接得到计算结果,不生成目标代码。 存储区内容:编译方式翻译和执行分开,解释方式翻译和执行同时并允许修改源程序,因此二者存储组织不同。 效率:解释慢于编译,很多语言两种方式都有。 标识符:=表达式 第三章:文法和语言 1.文法的直观概念:一组判定规则。 在实践中,文法不包含多余产生式。 2.文法G定义为四元组(VT,VN ,S, P ),其中: VT是一个非空有穷终结符号集合; VN是一个非空有穷的非终结符号集合,且VT∩VN=Φ; P是一个产生式的非空有穷集合(注意:产生式左部至少含有一个非终结符); S VN ,称为开始符号,且S至少必须在某个产生式的左部出现一次。 通常用V表示VN∪ VT,V称为文法G的字母表或字汇表. 3.句型、句子:设文法G,如果符号串x是从识别符号推导出来的,即S→x,x∈V*,则称x 是一个句型。仅含终结符号的句型是一个句子。 4.语言:语言 L(G)是由文法G产生的所有句子所组成的集合。 5文法的类型:逐渐对产生式施加限制四种类型:0型,1型,2型,3型

四川大学编译原理期末复习总结

一、简答题 1.什么是编译程序 答:编译程序是一种将高级语言程序(源程序)翻译成低级语言(目标程序)的程序。 将高级程序设计语言程序翻译成逻辑上等价的低级语言(汇编语言,机器语言)程序的翻译程序。 2.请写出文法的形式定义 答:一个文法G抽象地表示为四元组 G=(Vn,Vt,P,S) –其中Vn表示非终结符号 –Vt表示终结符号,Vn∪Vt=V(字母表),Vn∩Vt=φ –S是开始符号, –P是产生式,形如:α→β(α∈V+且至少含有一个非终结符号,β∈V*) 3.语法分析阶段的功能是什么 答:在词法分析的基础上,根据语言的语法规则,将单词符号串分解成各类语法短语(例:程序、语句、表达式)。确定整个输入串是否构成语法上正确的程序。 4.局部优化有哪些常用的技术 答:优化技术1—删除公共子表达式 优化技术2—复写传播 优化技术3—删除无用代码 优化技术4—对程序进行代数恒等变换(降低运算强度) 优化技术5—代码外提 优化技术6—强度削弱 优化技术7—删除归纳变量 优化技术简介——对程序进行代数恒等变换(代数简化) 优化技术简介——对程序进行代数恒等变换(合并已知量) 5.编译过程分哪几个阶段 答:逻辑上分五个阶段:词法分析、语法分析、语义分析与中间代码生成、代码优化、目标代码生成。每个阶段把源程序从一种表示变换成另一种表示。 6. 什么是文法 答:文法是描述语言的语法结构的形式规则。是一种工具,它可用于严格定义句子的结构; 用有穷的规则刻划无穷的集合;文法是被用来精确而无歧义地描述语言的句子的构成方式;文法描述语言的时候不考虑语言的含义。 7. 语义分析阶段的功能是什么 答:对语法分析所识别出的各类语法范畴分析其含义,进行初步的翻译(翻译成中间代码); 并对静态语义进行审查。 8.代码优化须遵循哪些原则 答:等价原则:不改变运行结果 有效原则:优化后时间更短,占用空间更少 合算原则:应用较低的代价取得较好的优化效果 9.词法分析阶段的功能是什么 答:

编译原理期末复习

编译原理期末复习 鉴于编译原理马上就要期末考试,我将手中集中的一些资料上的题目进行了整理归类,每种类型题目给出了所涉及到的基本知识,然后对每类题目中的第一道例题进行了做法进行了讲解,剩下的例题请给大家作为练习,答案也都给出,希望对大家复习有所帮助,最后由于时间很紧,整理的有些仓促,整理中难免有遗漏或错误,请大家见谅。 注:下面出现的字母中,若无特别说明,小写英文字母为终结符,大写英文字母为非终结符,希腊字母为终结符与非终结符的任意组合。 1、简答题(或者名词解释) 下面涉及到的概念中,加下划线的都是在以往一些试卷中出现的原题,务必掌握。 注:这类题目老师说答案不会超过一百个字,否则写的再多也不给分,有些点到即可,不要重复啰嗦。(1)简述编译程序的概念及其构成 答:1)编译程序:它特指把某种高级程序设计语言翻译成等价的低级程序设计语言的翻译程序。 2)构成: (2)简述词法分析阶段的主要任务(也有可能问语法分析阶段主要任务)答:词法分析的任务是输入源程序,对源程序进行扫描,识别其中的单词符号,把字符串形式的源程序转换成单词符号形式的源程序。 语法分析的主要任务是对输入的单词符号进行语法分析(根据语法规则进行推导或者归约),识别各类语法单位,判断输入是不是语法上正确的程序 (3) 简述编译程序的构造过程(这个大家看看,是对(1)和(2)的综合) 答:1)构造词法分析器:用于输入源程序进行词法分析,输出单词符号; 2)构造语法分析器:对输入的单词符号进行语法分析,识别各类语法单位,判断输入是不是语法上正确的程序 3)构造语义分析和中间代码产生器:按照语义规则对已归约出的语法单位进行语义分析并把它们翻译成中间代码。 4)构造优化器:对中间代码进行优化。 5) 构造目标代码生成器:把中间的代码翻译成目标程序。 6) 构造表格管理程序:登记源程序的各类信息和编译各阶段的进展情况。 7)构造错误处理程序:对出错进行处理。 (4) 说明编译和解释的区别: 1)编译要程序产生目标程序,解释程序是边解释边执行,不产生目标程序; 2)编译程序运行效率高而解释程序便于人机对话。 (5)文法:描述语言语法结构的形式规则,一般用一个四元式表示: G=(V T,V N,S,P),其中V T:终结符集合(非空) V N:非终结符集合(非空),且V T ?V N=? S:文法的开始符号,S?V N P:产生式集合(有限)。

《编译原理》模拟期末试题汇总 6套,含答案

《编译原理》模拟试题一 一、是非题(请在括号内,正确的划√,错误的划×)(每个2分,共20分) 1.计算机高级语言翻译成低级语言只有解释一种方式。(×) 2.在编译中进行语法检查的目的是为了发现程序中所有错误。(×) 3.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。 (√ ) 4.正则文法其产生式为 A->a , A->Bb, A,B∈VN , a 、b∈VT 。 (×) 5.每个文法都能改写为 LL(1) 文法。 (√) 6.递归下降法允许任一非终极符是直接左递归的。 (√) 7.算符优先关系表不一定存在对应的优先函数。 (×) 8.自底而上语法分析方法的主要问题是候选式的选择。 (×) 9.LR 法是自顶向下语法分析方法。 (×) 10.简单优先文法允许任意两个产生式具有相同右部。 (×) 二、选择题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)(每个4分,共40分) 1.一个编译程序中,不仅包含词法分析,_____,中间代码生成,代码优化,目标代码生成等五个部分。 A.( ) 语法分析B.( )文法分析C.( )语言分析D.( )解释分析 2.词法分析器用于识别_____。 A.( ) 字符串B.( )语句 C.( )单词 D.( )标识符 3.语法分析器则可以发现源程序中的_____。 A.( ) 语义错误 B.( ) 语法和语义错误 C.( ) 错误并校正D.( ) 语法错误 4.下面关于解释程序的描述正确的是_____。

(1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和 FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A.( ) (1)(2) B.( ) (1)C.( ) (1)(2)(3) D.( ) (2)(3) 5.解释程序处理语言时 , 大多数采用的是_____方法。 A.( ) 源程序命令被逐个直接解释执行 B.( ) 先将源程序转化为中间代码 , 再解释执行 C.( ) 先将源程序解释转化为目标程序 , 再执行 D.( ) 以上方法都可以 6.编译过程中 , 语法分析器的任务就是_____。 (1) 分析单词是怎样构成的 (2) 分析单词串是如何构成语句和说明的 (3) 分析语句和说明是如何构成程序的 (4) 分析程序的结构 A.( ) (2)(3) B.( ) (2)(3)(4) C.( ) (1)(2)(3) D.( ) (1)(2)(3)(4) 7.编译程序是一种_____。 A. ( ) 汇编程序B.( ) 翻译程序 C.( ) 解释程序 D.( ) 目标程序 8.文法 G 所描述的语言是_____的集合。 A. ( ) 文法 G 的字母表 V 中所有符号组成的符号串 B.( ) 文法 G 的字母表 V 的闭包 V* 中的所有符号串 C.( ) 由文法的开始符号推出的所有终极符串 D. ( ) 由文法的开始符号推出的所有符号串 9.文法分为四种类型,即0型、1型、2型、3型。其中3型文法是_____。 A. ( ) 短语文法 B.( ) 正则文法 C.( ) 上下文有关文法 D.( ) 上下文无关文法 10.一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组 _____。 A.( ) 句子B.( ) 句型 C.( ) 单词 D.( ) 产生式 三、填空题(每空1分,共10分)

【新版】《编译原理》期末复习

《编译原理》期末复习 【题型】 一、填空题:每空1分,共10分; 二、单选题:每题2分,共20分; 三、应用题:每小题6分,共48分; 四、综合分析题:每小题11分,共22分。 【知识点】 1.编译程序的整个过程从逻辑上依次分为哪6个阶段,其中还涉及哪2个重要工作。 2.语法分析有哪两大类方法? 3.编译程序和解释程序的概念,二者最主要的区别是? 4.句柄的定义。 5.什么是规范推导? 6.语言、句型、句子的定义。 7.LR分析法中的项目类型定义(待约项目、移入项目、归约项目)。 8.中间代码和目标代码区别。 9.文法与正则表达式所描述的语言及句子。 10.如何判断自动机(状态转换图)所能识别的字符串。 11.中间代码生成时主要依据什么规则? 12.根据给定文法,通过推导,画出指定句子的语法树。

13.自底向上的语法分析过程中,构造LR分析表时可能会面临的两种冲突。 14.判断源程序中出现的某类错误可能在编译的哪个阶段被发现。 15.词法分析及语法分析的输入输出是什么? 16.0、1、2、3型文法的定义、别名及描述能力强弱排名。 17.证明给定文法是二义性的(参考第二章课后练习)。 18.消除文法的左递归及提取公共左因子。 19.给定一个文法和该文法的句型,要求写出句型的最左推导、画出语法分析树、指出短语、简单短 语、句柄(参考第二章课后练习及课件中的例题)。 20.根据有限自动机的定义(五元组),给出其状态转换矩阵和状态转换图。 21.画出按照给定翻译模式分析某句子时所产生的分析树,分析其输出结果(参考第六章课后练习及 课件中的例题)。 22.针对给定的语言构造一个文法G,然后判断该文法类型(0、1、2、3型)(参考第二章课后练习)。 23.根据有限自动机M的定义(五元组),画出M的状态转换图,并说明它所识别或接受的语言是 什么(参考课件第三章例题)。 24.给出一个复合表达式,写出该表达式的三元式和四元式(如:-a*(b+c)/d)。 25.判断某语法制导定义在给定输入下的输出结果,分析文法产生的语言,指出语法制导定义功能。 26.已知文法及其LR分析表,给出对该文法某个句子的分析过程。(参考例题及习题) 27.给定一个文法,消除其左递归和提取左公因子,求所有非终结符的FIRST和FOLLOW集,构造 该文法的LL(1)分析表,根据分析表给出某句子的分析过程(参考第四章课后练习)。

编译原理期末考试题目及答案

一、填空题(每空2分,共20分) 1.编译程序首先要识别出源程序中每个单词,然后再分析每个句子并翻译其意义。 2.编译器常用的语法分析方法有自底向上和自顶向下两种。 3.通常把编译过程分为分析前端与综合后端两大阶段。词法、语法和语义分析是对源程序的分析,中间代码生成、代码优化与目标代码的生成则是对源程序的综合。 4.程序设计语言的发展带来了日渐多变的运行时存储管理方案,主要分为两大类,即静态存储分配方案和动态存储分配方案。 5.对编译程序而言,输入数据是源程序,输出结果是目标程序。 1.计算机执行用高级语言编写的程序主要有两种途径:解释和编译。 2.扫描器是词法分析器,它接受输入的源程序,对源程序进行词法分析并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。 3.自下而上分析法采用移进、归约、错误处理、接受等四种操作。 4.一个LL(1)分析程序需要用到一张分析表和符号栈。 5.后缀式abc-/所代表的表达式是a/(b-c)。 二、单项选择题(每小题2分,共20分) 1.词法分析器的输出结果是__C。 A.单词的种别编码B.单词在符号表中的位置 C.单词的种别编码和自身值D.单词自身值 2.正规式M 1 和M 2 等价是指__C_。 A.M1和M2的状态数相等 B.M1和M2的有向边条数相等 C.M1和M2所识别的语言集相等D.M1和M2状态数和有向边条数相等 3.文法G:S→xSx|y所识别的语言是_C____。 A.xyx B.(xyx)* C.xnyxn(n≥0) D.x*yx* 4.如果文法G是无二义的,则它的任何句子α_A____。 A.最左推导和最右推导对应的语法树必定相同B.最左推导和最右推导对应的语法树可能不同 C.最左推导和最右推导必定相同D.可能存在两个不同的最左推导,但它们对应的语法树相同5.构造编译程序应掌握____D__。 A.源程序B.目标语言C.编译方法D.以上三项都是 6.四元式之间的联系是通过__B___实现的。 A.指示器B.临时变量C.符号表D.程序变量 7.表达式(┐A∨B)∧(C∨D)的逆波兰表示为__B___。 A.┐AB∨∧CD∨B.A┐B∨CD∨∧ C.AB∨┐CD∨∧D.A┐B∨∧CD∨ 8. 优化可生成__D___的目标代码。 A.运行时间较短 B.占用存储空间较小 C.运行时间短但占用内存空间大D.运行时间短且占用存储空间小 9.下列___C___优化方法不是针对循环优化进行的。 A. 强度削弱B.删除归纳变量C.删除多余运算D.代码外提 10.编译程序使用_B_区别标识符的作用域。 A. 说明标识符的过程或函数名B.说明标识符的过程或函数的静态层次 C.说明标识符的过程或函数的动态层次 D. 标识符的行号 三、判断题(对的打√,错的打×,每小题1分,共10分) 2.一个有限状态自动机中,有且仅有一个唯一的终态。x

最新编译原理试题汇总+编译原理期末试题(8套含答案+大题集)

编译原理考试题及答案汇总一、选择 1.将编译程序分成若干个“遍”是为了_B__。 A . 提高程序的执行效率 B.使程序的结构更加清晰 C. 利用有限的机器内存并提高机器的执行效率 D.利用有限的机器内存但降低了机器的执行效率 2.正规式 MI 和 M2 等价是指__C__。 A . MI 和 M2 的状态数相等 B.Ml 和 M2 的有向弧条数相等。 C .M1 和 M2 所识别的语言集相等 D. Ml 和 M2 状态数和有向弧条数相等 3.中间代码生成时所依据的是 _C_。 A.语法规则 B.词法规则 C.语义规则 D.等价变换规则 4.后缀式 ab+cd+/可用表达式__B_来表示。 A. a+b/c+d B.(a+b)/(c+d) C. a+b/(c+d) D. a+b+c/d 6.一个编译程序中,不仅包含词法分析,_A____,中间代码生成,代码优化,目标代码生成等五个部分。 A.( ) 语法分析 B.( )文法分析 C.( )语言分析 D.( )解释分析 7.词法分析器用于识别__C___。 A.( ) 字符串 B.( )语句 C.( )单词 D.( )标识符 8.语法分析器则可以发现源程序中的___D__。 A.( ) 语义错误 B.( ) 语法和语义错误 C.( ) 错误并校正 D.( ) 语法错误 9.下面关于解释程序的描述正确的是__B___。 (1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和 FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A.( ) (1)(2) B.( ) (1) C.( ) (1)(2)(3) D.( ) (2)(3) 10.解释程序处理语言时 , 大多数采用的是__B___方法。 A.( ) 源程序命令被逐个直接解释执行 B.( ) 先将源程序转化为中间代码 , 再解释执行 C.( ) 先将源程序解释转化为目标程序 , 再执行 D.( ) 以上方法都可以 11.编译过程中 , 语法分析器的任务就是__B___。 (1) 分析单词是怎样构成的 (2) 分析单词串是如何构成语句和说明的 (3) 分析语句和说明是如何构成程序的 (4) 分析程序的结构 A.( ) (2)(3) B.( ) (2)(3)(4)C.( ) (1)(2)(3) D.( ) (1)(2)(3)(4) 12.编译程序是一种___C__。 A. ( ) 汇编程序 B.( ) 翻译程序 C.( ) 解释程序 D.( ) 目标程序 13.文法 G 所描述的语言是_C____的集合。 A. ( ) 文法 G 的字母表 V 中所有符号组成的符号串 B.( ) 文法 G 的字母表 V 的闭包 V* 中的所有符号串 C.( ) 由文法的开始符号推出的所有终极符串 D. ( ) 由文法的开始符号推出的所有符号串 14.文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 3 型文法是___B__。 A. ( ) 短语文法 B.( ) 正则文法 C.( ) 上下文有关文法 D.( ) 上下文无关文法15.一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组 __D___。 A.( ) 句子 B.( ) 句型 C.( ) 单词 D.( ) 产生式

期末考试编译原理试卷及答案

一. 填空题(每空2分,共20分) 1. 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静 态存储分配方案和动态存储分配方案,而后者又分为(1) 和 (2) 。 2. 规范规约是最(3)规约。 3. 编译程序的工作过程一般划分为5个阶段:词法分析、(4) 、语义分析与中间代码生成,代码优化及(5) 。另外还有(6)和出错处理。 4.表达式x+y*z/(a+b)的后缀式为 (7) 。 5.文法符号的属性有综合属性和 (8)。 6.假设二位数组按行存放,而且每个元素占用一个存储单元,则数组a[1..15,1..20]某个元素a[i ,j]的地址 计算公式为(9)。 7.局部优化是局限于一个(10)范围内的一种优化。 二. 选择题(1-6为单选题,7-8为多选题,每问2分,共20分) 1. 一个上下文无关文法G 包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组 ( )。 A . 字符串 B . 产生式 C . 开始符号 D . 文法 2.程序的基本块是指( )。 A . 一个子程序 B . 一个仅有一个入口和一个出口的语句 C . 一个没有嵌套的程序段 D . 一组顺序执行的程序段,仅有一个入口和一个出口 3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于( )分析方法。 A . 自左向右 B . 自顶向下 C . 自底向上 D . 自右向左 4.在通常的语法分析方法中,( )特别适用于表达式的分析。 A . 算符优先分析法 B . LR 分析法 C . 递归下降分析法 D . LL (1)分析法 5.经过编译所得到的目标程序是( )。 A . 四元式序列 B . 间接三元式序列 C . 二元式序列 D . 机器语言程序或汇编语言程序 6. 一个文法所描述的语言是( );描述一个语言的文法是( )。 A . 唯一的 B . 不唯一的 C . 可能唯一,也可能不唯一 7. 如果在文法G 中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。 A . 其最左推导和最右推导相同 B . 该句子有两个不同的最左推导 C . 该句子有两个不同的最右推导 D . 该句子有两棵不同的语法树

编译原理试题(卷)汇总-编译原理期末试题(卷)(8套含答案解析-大题集)

编译原理考试题及答案汇总 一、选择 1.将编译程序分成若干个“遍”是为了_B__。 A . 提高程序的执行效率 B.使程序的结构更加清晰 C. 利用有限的机器内存并提高机器的执行效率 D.利用有限的机器内存但降低了机器的执行效率 2.正规式 MI 和 M2 等价是指__C__。 A . MI 和 M2 的状态数相等 B.Ml 和 M2 的有向弧条数相等。 C .M1 和 M2 所识别的语言集相等 D. Ml 和 M2 状态数和有向弧条数相等 3.中间代码生成时所依据的是 _C_。 A.语法规则 B.词法规则 C.语义规则 D.等价变换规则 4.后缀式 ab+cd+/可用表达式__B_来表示。 A. a+b/c+d B.(a+b)/(c+d) C. a+b/(c+d) D. a+b+c/d 6.一个编译程序中,不仅包含词法分析,_A____,中间代码生成,代码优化,目标代码生成等五个部分。 A.( ) 语法分析 B.( )文法分析 C.( )语言分析 D.( )解释分析 7.词法分析器用于识别__C___。 A.( ) 字符串 B.( )语句 C.( )单词 D.( )标识符 8.语法分析器则可以发现源程序中的___D__。 A.( ) 语义错误 B.( ) 语法和语义错误 C.( ) 错误并校正 D.( ) 语法错误 9.下面关于解释程序的描述正确的是__B___。 (1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和 FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A.( ) (1)(2) B.( ) (1) C.( ) (1)(2)(3) D.( ) (2)(3) 10.解释程序处理语言时 , 大多数采用的是__B___方法。 A.( ) 源程序命令被逐个直接解释执行 B.( ) 先将源程序转化为中间代码 , 再解释执行 C.( ) 先将源程序解释转化为目标程序 , 再执行 D.( ) 以上方法都可以 11.编译过程中 , 语法分析器的任务就是__B___。 (1) 分析单词是怎样构成的 (2) 分析单词串是如何构成语句和说明的 (3) 分析语句和说明是如何构成程序的 (4) 分析程序的结构 A.( ) (2)(3) B.( ) (2)(3)(4)C.( ) (1)(2)(3) D.( ) (1)(2)(3)(4) 12.编译程序是一种___C__。 A. ( ) 汇编程序 B.( ) 翻译程序 C.( ) 解释程序 D.( ) 目标程序 13.文法 G 所描述的语言是_C____的集合。 A. ( ) 文法 G 的字母表 V 中所有符号组成的符号串 B.( ) 文法 G 的字母表 V 的闭包 V* 中的所有符号串 C.( ) 由文法的开始符号推出的所有终极符串 D. ( ) 由文法的开始符号推出的所有符号串 14.文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 3 型文法是___B__。 A. ( ) 短语文法 B.( ) 正则文法 C.( ) 上下文有关文法 D.( ) 上下文无关文法15.一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组 __D___。 A.( ) 句子 B.( ) 句型 C.( ) 单词 D.( ) 产生式 16.通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括_C____。

(2020年整理)编译原理期末总复习题(含答案).doc

第八节习题一、单项选择题 1、将编译程序分成若干个“遍”是为了 b 。 a.提高程序的执行效率 b.使程序的结构更加清晰 c.利用有限的机器内存并提高机器的执行效率 d.利用有限的机器内存但降低了机器的执行效率 2、构造编译程序应掌握 d 。 a.源程序b.目标语言 c.编译方法d.以上三项都是 3、变量应当 c 。 a.持有左值b.持有右值 c.既持有左值又持有右值d.既不持有左值也不持有右值 4、编译程序绝大多数时间花在 b 上。 a.出错处理b.词法分析 c.目标代码生成d.管理表格 5、 d 不可能是目标代码。 a.汇编指令代码b.可重定位指令代码 c.绝对指令代码d.中间代码 6、使用 a 可以定义一个程序的意义。 a.语义规则b.词法规则 c.产生规则d.词法规则 7、词法分析器的输入是 a 。 a.单词符号串b.源程序 c.语法单位d.目标程序 8、中间代码生成时所遵循的是- d 。 a.语法规则b.词法规则 c.语义规则d.等价变换规则 9、编译程序是对 d 。 a.汇编程序的翻译b.高级语言程序的解释执行 c.机器语言的执行d.高级语言的翻译 10、语法分析应遵循 b 。 a.语义规则b.语法规则 c.构词规则d.等价变换规则 解答 1、将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选b。 2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选d。 3、对编译而言,变量既持有左值又持有右值,故选c。 4、编译程序打交道最多的就是各种表格,因此选d。 5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,因此不是目标代码的只能选d。 6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。因此选a。 7、b 8、c 9、d 10、c 二、多项选择题

编译原理期末复习题

3.2是非判断,对下面的述,正确的在述后的括号写T,否则写F。 (1)有穷自动机接受的语言是正则语言。() (2)若r1和r2是Σ上的正规式,则r1|r2也是。() (3)设M是一个NFA,并且L(M)={x,y,z},则M的状态数至少为4个。() (4)令Σ={a,b},则Σ上所有以b为首的字构成的正规集的正规式为b*(a|b)*。() (5)对任何一个NFA M,都存在一个DFA M',使得L(M')=L(M)。() (6)对一个右线性文法G,必存在一个左线性文法G',使得L(G)=L(G'),反之亦然。() 答案 (1) T (2) T (3) F (4) F (5) T (6) T 3.3描述下列各正规表达式所表示的语言。 (1) 0(0|1)*0 (2) ((ε|0)1*)* (3) (0|1)*0(0|1)(0|1) (4) 0*10*10*10* (5) (00|11)*((01|10)(00|11)*(01|10)(00|11)*)* 答案 (1) 以0开头并且以0结尾的,由0和1组成的符号串。 (2) {α|α∈{0,1}*} (3) 由0和1组成的符号串,且从右边开始数第3位为0。 (4) 含3个1的由0和1组成的符号串。{α|α∈{0,1}+,且α中含有3个1 } (5) {α|α∈{0,1}*,α中0和1为偶数} 3.4对于下列语言分别写出它们的正规表达式。 (1) 英文字母组成的所有符号串,要求符号串中顺序包含五个元音。 (2) 英文字母组成的所有符号串,要求符号串中的字母依照词典顺序排列。 (3) Σ={0,1}上的含偶数个1的所有串。 (4) Σ={0,1}上的含奇数个1的所有串。 (5) 具有偶数个0和奇数个1的有0和1组成的符号串的全体。 (6) 不包含子串011的由0和1组成的符号串的全体。 (7) 由0和1组成的符号串,把它看成二进制数,能被3整除的符号串的全体。 答案 (1) 令Letter表示除这五个元音外的其它字母。 ((letter)*A(letter)*E(letter)*I(letter)*O(letter)*U(letter))* (2) A*B*....Z* (3) (0|10*1)* (4) (0|10*1)*1

《编译原理》期末考试复习题

《编译原理》期末考试复习题 一、是非题(请在括号内,正确的划√,错误的划×)(每个2分,共20分) ×1.计算机高级语言翻译成低级语言只有解释一种方式。() ×2.在编译中进行语法检查的目的是为了发现程序中所有错误。() √3.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。 () ×4.正则文法其产生式为 A->a , A->Bb, A,B∈VN , a 、b∈VT 。 () √5.每个文法都能改写为 LL(1) 文法。 () √6.递归下降法允许任一非终极符是直接左递归的。 () ×7.算符优先关系表不一定存在对应的优先函数。 () ×8.自底而上语法分析方法的主要问题是候选式的选择。 () ×9.LR 法是自顶向下语法分析方法。 () ×10.简单优先文法允许任意两个产生式具有相同右部。 () 三、填空题(每空1分,共10分) 1.编译程序的工作过程一般可以划分为词法分析,语法分析,语义分析,中间代码生成,代码优化等几个基本阶段,同时还会伴有__ ___和 ___ _。 表格管理出错处理_ 2.若源程序是用高级语言编写的,__ __是机器语言程序或汇编程序,则其翻译程序称为 __ __ 。 _目标程序_编译程序 3.编译方式与解释方式的根本区别在于__ __。 是否生成目标代码_ 4.对编译程序而言,输入数据是__ __, 输出结果是__ ___。 _源程序目标程序

5.产生式是用于定义__ __的一种书写规则。 _语法成分 6.语法分析最常用的两类方法是___ __和__ __分析法。 自上而下_自下而上 四、简答题(20分) 1. 什么是句子?什么是语言 ? 答:(1)设G是一个给定的文法,S是文法的开始符号,如果S x(其中x∈VT*),则称x是文法的一个句子。 (2)设G[S]是给定文法,则由文法G所定义的语言L(G)可描述为:L(G)={x│S x,x∈VT*} 。 一、是非题(请在括号内,正确的划√,错误的划×)(每个2分,共20分) ×1.对于数据空间的存贮分配,FORTRAN采用动态贮存分配策略。() ×2.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。() √3.递归下降分析法是自顶向上分析方法。() ×4.产生式是用于定义词法成分的一种书写规则。() √5.LR 法是自顶向下语法分析方法。() √6.在SLR (1 )分析法的名称中,S的含义是简单的。() ×7.综合属性是用于“ 自上而下” 传递信息。() ×8.符号表中的信息栏中登记了每个名字的属性和特征等有关信息,如类型、种属、所占单元大小、地址等等。() ×9.程序语言的语言处理程序是一种应用软件。() ×10.解释程序适用于COBOL 和FORTRAN 语言。() 三、填空题(每空1分,共10分) 1.一个句型中的最左简单短语称为该句型的___句柄__。

编译原理考试试卷

南京工业大学继续教育学院编译原理期末考试试卷 (2012-2013学年) A卷 一、选择题(每题2分,共20分) 得分 1. 一个上下文无关文法G包括四个组成部分:一组终结符,一组非终结符,一个_____,以及一组产生式。 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.正规式M 1 和M 2 等价是指_____。

A.( ) M1和M2的状态数相等B.( ) M1和M2的有向边条数相等 C.( ) M1和M2所识别的语言集相等D.( ) M1和M2状态数和有向边条数相等 8.文法G:S→xSx|y所识别的语言是_____。 A.( ) xyx B.( ) (xyx)* C.( ) xnyxn(n≥0) D.( ) x*yx* 9.语言是_____。 A.句子的集合B.产生式的集合 C.符号串的集合D.句型的集合 10.编译程序前三个阶段完成的工作是 A.词法分析、语法分析和代码优化 B.代码生成、代码优化和词法分析 C.词法分析、语法分析、语义分析和中间代码生成 D.词法分析、语法分析和代码优化 二、名词解释(每题2分,共20分) 得分 1.最左推导: 2.语法: 3.文法: 4.基本块: 5.语法制导翻译: 6.短语: 7.规范句型:

编译原理期末复习

编译原理 一、单选题 1、将编译程序分为若干个“遍”是为了()。B A.提高程序的执行效率 B.使程序的结构更加清晰 C.利用有限的机器内存并提高机器的执行效率 D.利用有限的机器内存但降低了机器的执行效率 2、构造编译程序应掌握()。D A.源程序 B.目标语言 C.编译方法 D.以上三项都是 3、变量应当()。C A.持有左值 B.持有右值 C.既持有左值又持有右值 D.既不持有左值也不持有右值 4、编译程序绝大多数时间花在()上。D A.出错处理 B.词法分析 C.目标代码生成 D.管理表格 5、()不可能是目标代码。D A.汇编指令代码 B.可重定位指令代码

C.绝对指令代码 D.中间代码 6、编译程序是对()。D A.汇编程序的翻译 B.高级语言程序的解释执行 C.机器语言的执行 D.高级语言的翻译 7、正规式M1和M2等价是指()。C A.M1和M2的状态数相等和M2的有象弧条数相等 和M2所识别的语言集相等和M2状态数和有象弧条数相等 8、如果文法G是无二义的,则它的任何句子()。A A.最左推导和最右推导对应的语法树必定相同。 B.最左推导和最右推导对应的语法树可能相同。 C.最左推导和最右推导必定相同。 D.可能存在两个不同的最左推导,但它们对应的语法树相同。 9、文法G:S→S+T|T T→T*P|P P→(S)|i 句型P+T+i的短语有()B A.i,P+T B. P,P+T,i,P+T +i +T + i D. P,P+T,i

10、产生正规语言的文法为()。D 型型型型 11、文法G:S→b|?|(T) T→T?S|S 则FIRSTVT(T)=() C A.{b,?,(} B.{b,?,)} C.{b,?,(,?} D.{b,?,),?} 12、给定文法:A→bA | cc,下面的符号串中,为该文法句子的是()。A cc bcbc bcbcc ④bccbcc ⑤bbbcc 可选项有: A. B.④⑤ C.④ D.④⑤ 13、采用自上而下分析,必须()。C A.消除左递归 B.消除右递归 C.消除回溯 D.提取公共左因子 14、由文法的开始符经0步或多步推导产生的文法符号序列是()。C A.短语 B.句柄 C.句型 D.句子 15、后缀式ab+cd+/可用表达式()来表示。B

编译原理2011期末考试试卷答案

2011~ 2012 学年第 1 学期期末考试试卷答案 《编译原理》(共 4 页) (考试时间: 2011 年 12 月 25 日) 一、选择题(每题 1 分,共 10 分) 1.B 2.D 3.A 4.D 5.D 6.C 7.B 8.C 9.D 10.B 二、简答题(每题 5 分,共 20 分) 1.何谓二义性文法?试举一例说明。 答:若文法G 的一个句子对应有两棵或两棵以上不同的推导树,则称该句子是 二义性的。产生二义性句子的文法称为二义性文法,否则该文法是无二义性的。 例子:给定文法G[] : *||a|b 考察句子 ab*,它有两棵不同的推导树,如下所示: * a * b a b a 2.通过合并 LR(1) 文法中的同心状态得到的 LALR(1) 文法可能会产生哪些冲突?一定不会产生哪些冲突?为什么? 答:可能会产生归约 -归约冲突,一定不会产生移进 -归约冲突。 因为在对 LR(1) 合并同心集合时,有可能将原本没有冲突的同心集的项目集 合并后造成一些归约项目向前搜索符集合的交集不是空,产生归约-归约冲突。但是由于文法本身已经是LR(1) 文法,因此可知,在项目集中一定不存在移进 -归约冲突,也就是移进项目要求输入的终结符和任意归约项目的向前搜索符集合的交集都是空集。这样,在将同心集合并之后,移进项目要求输入的终结符和归约项目的向前搜索符集合的交集也还是空集。 3.自顶向下的预测分析方法为什么不能分析具有左递归的文法? 答:在自顶向下的语法分析技术中,要解决的问题是根据当前输入符号判断将识 别符号以及非终结符号替换成哪条规则的右部,若文法具有左递归,则在分析过程中,无法判断替换的规则,造成无穷递归求解过程。 4.设 G=(V N,V T, P,)是上下文无关文法,产生式集合P 中任意一个产生式应具有什么样的形式?若G 是正则文法呢? 答:上下文无关文法的产生式形式为: A →α,其中, A ∈ V N,α∈( V N∪V T)* 正则文法产生式形式为: N,a∈V T A→,或→ (右线性文法)其中,A,B ∈V aBA a A→Ba,或 A → a(左线性文法)其中, A,B ∈ V N, a∈V T 三、推导题(共70 分) 1.对于文法 G[S]:

编译原理期末试题及答案

2、写出表达式a+b*(c-d)/e的逆波兰式和三元序列。 3、写出表达式a:=(b+c)*e+(b+c)/f的逆波兰式和三元序列。 4、已知文法G(S)及相应翻译方案 S→aAb {print “1”} S→a {print “2”} A→AS {print “3”} A→c {print “4”} 输入acab, 输出是什么 5、已知文法G(S) S→bAa A→(B | a B→Aa) 写出句子b(aa)b的规范归约过程。 6、已知文法G[S] S→S*aF | aF | *aF F→+aF | +a 消除文法左递归。 1、设文法G(S): S→^ | a | (T) T→T,S | S ⑴消除左递归; ⑵构造相应的FIRST和FOLLOW集合; ⑶构造预测分析表 2.语句if E then S (1) 改写文法,使之适合语法制导翻译; (2) 写出改写后产生式的语义动作。 4.设某语言的for语句的形式为 for i:=E(1) to E(2) do S 其语义解释为 i:=E(1) LIMIT:=E(2) again: if i<=LIMIT then Begin S; i:=i+1 goto again End; (1)写出适合语法制导翻译的产生式; (2)写出每个产生式对应的语义动作。 7.已知文法G(S) S→a | ^ | (T) T→T,S | S (1) 给出句子(a,(a,a))的最左推导; (2) 给出句型((T,S),a)的短语, 直接短语,句柄。 8.对于C 语言do S while E语句 (1)改写文法,使之适合语法制导翻译;

(2)写出改写后产生式的语义动作。 9.已知文法G(S) S→aAcBe A→Ab| b B→d (1)给出句子abbcde的最左推导及画出语法树; (2)给出句型aAbcde的短语、素短语。 10.设文法G(S): S→(T) | aS | a T→T,S | S ⑴消除左递归和提公共左因子; ⑵构造相应的FIRST和FOLLOW集合; ⑶构造预测分析表。 12.已知文法G(S) E→E+T | T T→T*F| F F→(E)| i (1) 给出句型(i+i)*i+i的最左推导及画出语法树; (2) 给出句型(E+T)*i+F 的短语,素短语和最左素短语。 答案: (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) C→if E then S→CS(1) (2) C→if E then {BACK, NXQ); :=} S→CS(1) {:=MERG, S(1). Chain)} 4. (1) F→for i:=E(1) to E(2) do S→FS(1) (2)F→for i:=E(1) to E(2) do {GEN(:=, E(1).place, _, entry(i)); :=entry(i);

相关主题