编译原理模拟试卷

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

说明:向学生提供这门课程的4份模拟考试试题与答案。试题最好分开放题和客观题两类,客观题提供答案,开放题提供解题思路。如果期末的评估要求学员提交论文或作品,教师需提供评价标准。

模拟试卷

模拟试卷A

一、处于/* 和*/之间的串构成注解,注解中间没有*/,请根据词法分析基本方法,画出接受这种注解的DFA的状态转换图。

二、根据自上而下的语法分析方法,构造下面文法的LL(1)分析表。

D → TL

T → int | real

L → id R

R → , id R | ε

三、根据自下而上的语法分析方法,为下面文法构造规范LR(1)分析表,画出状态转换图就可以了。然后说明它是否有动作冲突。

S →V = E | E

V →*E | id

E →V

四、何谓语法制导的定义?为下面文法写一个语法制导的定义,它完成一个句子的while-do最大嵌套层次的计算并输出这个计算结果。

S → E

E →while E do E | id := E | E + E | id | (E)

五、请根据数据流分析方法,对下面的程序片段作出其程序流图并计算:(1)各基本块的到达_定值集IN[B];

(2)各基本块中各变量引用点的ud链;

I := 1

J := 0

L1: J := J + I

read I

if I < 100 goto L2

write J

halt

L2 : I := I * I

goto L1

模拟试卷B

一、叙述下面的正规式描述的语言,并画出接受该语言的最简DFA的状态转换图。

( 1 | 01 )* 0*

二、(1)通过构造识别活前缀的DFA和构造分析表,来证明文法E → E + id | id 是SLR(1)文法。

(2)下面左右两个文法都和(1)的文法等价

E → E + M id | id E → M E + id | id

M →εM →ε

请指出其中有几个文法不是LR(1)文法,并给出它们不是LR(1)文法的理由。

三、为下面的算术表达式文法写一个语法制导的翻译方案,它将每个子表达式E 的符号(即值大于零还是小于零)记录在属性E.sign中(属性值分别用POS或NEG表示)。你可以假定所有的整数都不为零,这样就不用担心零的符号。

E→E *E | +E | -E | unsigned_integer

四、一个C语言程序如下:

func(i1,i2,i3)

long i1,i2,i3;

{

long j1,j2,j3;

printf("Addresses of i1,i2,i3 = %o,%o,%o\n",&i1,&i2,&i3);

printf("Addresses of j1,j2,j3 = %o,%o,%o\n",&j1,&j2,&j3);

}

main()

{

long i1,i2,i3;

func(i1,i2,i3);

}

该程序在某种机器的Linux上的运行结果如下:

Addresses of i1,i2,i3 = 27777775460,27777775464,27777775470 Addresses of j1,j2,j3 = 27777775444,27777775440,27777775434

从上面的结果可以看出,func 函数的3个形式参数的地址依次升高,而3个局部变量的地址依次降低。试说明为什么会有这个区别。

五、考虑下面的三地址语句序列:

b := 1

b := 2

if w <= x goto L2

e := b

goto L2

L1: goto L3

L2: c := 3

b := 4

c := 6

L3: if y <= z goto L4

goto L5

L4: g := g + 1

h := 8

goto L1

L5: h := 9

(1)在该代码中用水平的横线将代码分成基本块,并给每个基本块一个序号。

(2)画出该代码的控制流图,每个基本块就用(1)的序号表示。

(3)若有循环的话,列出构成每个循环的结点。

模拟试卷C

一、下面是用正规式表示的变量声明:

( int | float ) id (, id )* ;

请改用上下文无关文法表示,也就是写一个上下文无关文法,它和该正规式等价。

二、下面的文法产生代表正二进制数的0和1的串集:

B → B 0 | B 1 | 1

下面的翻译方案计算这种正二进制数的十进制值:

B → B1 0 {B.va l := B1.val⨯ 2 }

| B1 1 {B.val := B1.val⨯ 2 +1}

| 1 {B.val := 1 }

请消除该基础文法的左递归,再重写一个翻译方案,它仍然计算这种正二进制数的十进制值。

三、为下面文法写一个语法制导的定义,用S的综合属性val给出下面文法中S 产生的二进制数的值。例如,输入101.101时,S. val := 5.625。(不得修改文法。)S → L . R | L

L → L B | B

R → B R | B

B → 0 | 1

四、对于下面C语言文件s.c

f1(int x)

{

long x;

x = 1;

}

f2(int x)

{

{

long x;

x = 1;

}

}

某编译器编译时报错如下:

s.c: In function ‘f1’:

s.c:3: warning: declaration of ‘x’ shadows a parameter

请回答,对函数f2为什么没有类似的警告错误。

五、考虑一个简单语言,其中所有的变量都是整型(不需要显式声明),并且仅包含赋值语句、读语句和写语句。下面的产生式定义了该语言的语法(其中lit 表示整型常量;OP的产生式没有给出,因为它和下面讨论的问题无关)。

Program →StmtList

StmtList →Stmt StmtList | Stmt

Stmt →id := Exp; | read (id ); | write ( Exp );

Exp →id | lit | Exp OP Exp

我们把不影响write语句输出值的赋值(包括通过read语句来赋值)称为无用赋值,写一个语法指导定义,它确定一个程序中出现过赋予无用值的变量集合(不需要知道无用赋值的位置)和没有置初值的变量集合(不影响write语句输出值的未置初值变量不在考虑之中)。

非终结符StmtList和Stmt用下面3个属性(你根据需要来定义其它文法符号的属性):

(1)uses_in:在本语句表或语句入口点的引用变量集合,它们的值影响在该程序点后的输出。

(2)uses_out:在本语句表或语句出口点的引用变量集合,它们的值影响在该程序点后的输出。

(3)useless:本语句表或语句中出现的无用赋值变量集合。

模拟试卷D

一、描述由正规式b*(abb*)*(a| ε)定义的语言,并画出接受该语言的最简DFA。

相关文档
最新文档