编译原理复习题答案

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

二、概念题

1、设有文法:P→P+Q|Q

Q→Q*R|R

R→(P)|i

(1)证明Q*R+Q+Q是它的一个句型。(3分)

(2)给出Q*R+Q+Q的所有短语,直接短语和句柄。(4分) (3)给出句子i+i*i的最右推导。(4分)

(4)给出句子i+i*i的最左推导。(4分)

2、设有文法:E→E+T|T T→T*F|F F→(E)|i (1)证明E+T*F是它的一个句型。(3分)

⇒+⇒+*

答案:E E T E T F

(2)给出E+T*F的所有短语,直接短语和句柄。(4分) 短语: E+T*F, T*F,

直接短语: T*F

句柄: T*F

(3)给出句子i+i*i的最右推导。(4分)

3、写出表达式a+b*(c-d)对应的逆波兰式和三元式序列。答案:逆波兰式:(abcd-*+)

三元式序列:

OP ARG1 ARG2

(1) - c d

(2) * b (1)

(3) + a (2)

三、词法分析题

给出下面语言的相应文法

L1={a n b n a m b m|n,m≥0}

答案:S→AB|A|B|∑

A→aAb|ab

B→aBb|ab

给出下面语言的相应文法

L2={a n b n c i|n≥1,i≥0}

答案:S→AB|B

A→a|aA

B→bBc|bc

给出下面语言的相应文法

L3={a n b n c m| m,n≥1,n为奇数,m为偶数}。

答案:文法G(S):S→AC

A→aaAbb/ab

C→ccCcc/cc

四、词法分析题

1、构造下面正规式相应的DFA

((0|1)*|(11)*)*

(要求:先将正规式转化为NFA,再将NFA确定化,最小化)2、构造下面正规式相应的DFA

1(0|1)*101

答案:

I I0 I1

{X} Ф{A,B,C}

{A,B,C} { B,C} { B,C,D}

{B,C} { B,C} { B,C,D}

{B,C,D} { B,C,E} { B,C,D}

{B,C,E} { B,C} {B,C,D,y}

{B,C,D,y} {B,C,E} { B,C,D}

3、构造一个DFA,它接受 ={a,b}上所有包含ab的字符串。(要求:先将正规式转化为NFA,再将NFA确定化,最小化)答案:(一)相应的正规式为(a|b)*ab(a|b)*

(二) ①和此正规式对应的NFA为

②状态转换矩阵为:

③ 最小化:

{0,1,2} {3,4,5} {0, 2},1, {3,4,5}

④所以此等价的DFA 为:开始状态为0 ,终态集为{3} ,状态集为{0,1,3} , 输入字母表是{a,b} 状态转换图如上。 等价的DFA 五、语法分析题 1、对下面的文法G: Expr →- Expr

Expr →(Expr)|Var ExprTail ExprTail →- Expr|ε Var →id VarTail VarTail →(Expr) |ε

(1) 构造LL(1)分析表。(12分) 答案:

(1)FIRST(Expr)={_ , ( , id } FIRST(ExprTail)={_ , ε } FIRST(Var)={id}

b

a

a 0 1 b

3 b

a

FIRST(VarTail)={ ( , ε}

FOLLOW(Expr)={# , ) } FOLLOW(ExprTail) ={# , ) } FOLLOW(Var) ={_ , # , ) } FOLLOW(VarTail) ={_ , # , ) }

(2)给出对句子id—id((id))的分析过程。(8分)

步骤符号栈输入串所用产生式

0 #Expr id_ _id((id))#

1 # ExprTail Var id_ _id((id))#Expr→Var ExprTail

2 # ExprTail VarTail id id_ _id((id))#Var→id VarTail

3 # ExprTail VarTail _ _id((id))#

4 # ExprTail _ _id((id))#VarTail→ε

5 # Expr_ _ _id((id))# ExprTail→_ Expr

6 # Expr _id((id))#

7 # Expr_ _id((id))#Expr→_Expr

8 # Expr id((id))#

9 # ExprTail Var id((id))#Expr→Var ExprTail

10 # ExprTail VarTail id id((id))#Var→id VarTail

11 # ExprTail VarTail ((id))#

12 # ExprTail )Expr( ((id))#VarTail→(Expr)

13 # ExprTail )Expr (id))#

14 # ExprTail ) )Expr( (id))#Expr→(Expr)

15 # ExprTail ) )Expr id))#

16# ExprTail ) ) ExprTail Var id))#Exp→Var ExprTail

17 # ExprTail ) )

ExprTail VarTail id id))#Var→id VarTail 18 # ExprTail ) )

ExprTail VarTail ))#

19 # ExprTail ) )

ExprTail ))#VarTail→ε

20 # ExprTail ) ) ))#ExprTail→ε

21 # ExprTail ) )#

22 # ExprTail # ExprTail→ε

23 # # 分析成功

2、对下面的文法G:

E→TE’

E’→+E|ε

T→FT’

T’→T|ε

相关文档
最新文档