编译原理模拟试卷
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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。