编译原理复习题考试.docx

上传人:b****6 文档编号:8115007 上传时间:2023-01-28 格式:DOCX 页数:32 大小:164.54KB
下载 相关 举报
编译原理复习题考试.docx_第1页
第1页 / 共32页
编译原理复习题考试.docx_第2页
第2页 / 共32页
编译原理复习题考试.docx_第3页
第3页 / 共32页
编译原理复习题考试.docx_第4页
第4页 / 共32页
编译原理复习题考试.docx_第5页
第5页 / 共32页
点击查看更多>>
下载资源
资源描述

编译原理复习题考试.docx

《编译原理复习题考试.docx》由会员分享,可在线阅读,更多相关《编译原理复习题考试.docx(32页珍藏版)》请在冰豆网上搜索。

编译原理复习题考试.docx

编译原理复习题考试

编译原理复习题

一、是非题

I•计算机高级语言翻译成低级语言只有解释一种方式。

(X)

3•每个文法都能改写为LL

(1)文法。

(X)

4•算符优先关系表不一定存在对应的优先函数。

(V)

5•LR分析方法是自顶向下语法分析方法。

(X)

6•“用高级语言书写的源程序都必须通过编译,产生目标代码后才能投入运行”这种说法。

(X

7.一个句型的句柄一定是文法某产生式的右部。

(V)

8.仅考虑一个基本块,不能确定一个赋值是否真是无用的。

(V)

9.在中间代码优化中循环上的优化主要有不变表达式外提和削减运算强度。

(X

10.对于数据空间的存贮分配,FORTRAN采用动态贮存分配策略。

(X

II•甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。

(X

12•递归下降分析法是自顶向下分析方法。

(V)

13•产生式是用于定义词法成分的一种书写规则。

(X

14.在SLR

(1)分析法的名称中,S的含义是简单的。

(V)

15•综合属性是用于“自上而下”传递信息。

(X

16•符号表中的信息栏中登记了每个名字的属性和特征等有关信息,如类型、种属、所占单元大小、地址等等。

(X

17.程序语言的语言处理程序是一种应用软件。

(X

18.解释程序适用于COBOL和FORTRAN语言。

(X

19.一个LL(l)文法一定是无二义的。

(V)

20.正规文法产生的语言都可以用上下文无关文法来描述。

(V)

21.一张转换图只包含有限个状态,其中有一个被认为是初态,最多只有一个终态。

(X)

22•目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。

(V)

22.逆波兰法表示的表达式亦称后缀式。

(V)

23.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义的。

(V)

24.数组元素的地址计算与数组的存储方式有关。

(V)

25.算符优先关系表不一定存在对应的优先函数。

(X

26.编译程序是对高级语言程序的解释执行。

(X

27.—个有限状态自动机中,有且仅有一个唯一的终态。

(X

28.—个算符优先文法可能不存在算符优先函数与之对应。

(V)

29.语法分析时必须先消除文法中的左递归。

(X

30.LR分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错地点。

(V)

31.逆波兰表示法表示表达式时无须使用括号。

(V)

32.静态数组的存储空间可以在编译时确定。

(V)

33.进行代码优化时应着重考虑循环的代码优化,这对提高目标代码的效率将起更大作用。

(V)

34.两个正规集相等的必要条件是他们对应的正规式等价。

(V)

35.—个语义子程序描述了一个文法所对应的翻译工作。

(X

36.设r和s分别是正规式,则有L(r|s)=L(r)L(s)。

(X

37.确定的自动机以及不确定的自动机都能正确地识别正规集。

(V)

38.词法分析作为单独的一遍来处理较好。

(X

39.构造LR分析器的任务就是产生LR分析表。

(V)

40.规范归约和规范推导是互逆的两个过程。

(V)

41.同心集的合并有可能产生新的移进”归约”冲突。

(X)

42.LR分析技术无法适用二义文法。

(X)

43.树形表示和四元式不便于优化,而三元式和间接三元式则便于优化。

(X

44•程序中的表达式语句在语义翻译时不需要回填技术。

(V)

45.对中间代码的优化依赖于具体的计算机。

(X

46.若一个句型中出现了某产生式的右部,则此右部一定是该句型的句柄。

(X

47.在程序中标识符的出现仅为使用性的。

(X

48.削减运算强度破坏了临时变量在一基本块内仅被定义一次的特性。

(X

49.编译程序与具体的机器有关,与具体的语言无关。

(X

二、选择题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)

1.一个编译程序中,不仅包含词法分析,(A),中间代码生成,代码优化,目标代码生成等五个部分。

A.语法分析B.文法分析C.语言分析D.解释分析

2.语法分析器则可以发现源程序中的(D)。

A.语义错误B•语法和语义错误C.错误并校正D.语法错误

3.解释程序处理语言时,大多数采用的是(B)方法。

A.源程序命令被逐个直接解释执行

B.先将源程序转化为中间代码,再解释执行

C.先将源程序解释转化为目标程序,再执行

D.以上方法都可以

4.编译程序是一种(B)。

A.汇编程序B.翻译程序C.解释程序D.目标程序

5.文法分为四种类型,即0型、1型、2型、3型。

其中3型文法是(B)。

A.短语文法B.正则文法C.上下文有关文法D.上下文无关文法

6.通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括(C)。

A.模拟执行器B.解释器C.表格处理和出错处理D.符号执行器

7.一个句型中的最左(B)称为该句型的句柄。

A.短语B.简单短语C.素短语D.终结符号

8.文法G[E]:

EFIE+T

—FIT*F

FfI(E)

该文法句型E+F*(E+T)的简单短语是下列符号串中的(B)。

①(E+T)②E+T

③F

④F*(E+T)

A.①和③B.②和

C.③和④

D.③

9.词法分析器用于识别(C)。

A.句子B.句型C

.单词

D.产生式

10.在自底向上的语法分析方法中,分析的关键是(A)。

A.寻找句柄B.寻找句型C.消除递归D.选择候选式

11.文法G产生的(D)的全体是该文法描述的语言。

A.句型B.终结符集C.非终结符集D.句子

12.若文法G定义的语言是无限集,则文法必然是(A)。

A.递归的B.前后文无关的C.二义性的D.无二义性的

13.四种形式语言文法中,1型文法又称为(C)文法。

A.短语结构文法B.前后文无关文法C.前后文有关文法D.正规文法

14.一个文法所描述的语言是(A)。

A.唯一的B.不唯一的C.可能唯一,好可能不唯一D.都不对

A.维数B.类型C.维上下界D.各维的界差

18.一个上下文无关文法G包括四个组成部分,它们是:

一组非终结符号,一组终结符号,一个开始符号,以及一组(D)。

C.单词D.产生式

0型、1型、2型、3型。

其中2型文法是(D)。

C.上下文有关文法D.上下文无关文法

A.句子B.句型

19.文法分为四种类型,即

A.短语文法B.正则文法

20.文法G所描述的语言是(C)的集合。

A.文法G的字母表V中所有符号组成的符号串B.文法G的字母表V的闭包V*中的所有符号串

C.由文法的开始符号推出的所有终极符串D.由文法的开始符号推出的所有符号串

21.词法分析器用于识别(C)。

A.字符串B.语句C.单词D.标识符

22.文法分为四种类型,即0型、1型、2型、3型。

其中0型文法是(A)。

D.上下文无关文法

A.短语文法B.正则文法C.上下文有关文法

24.(A)是一种典型的解释型语言。

A.BASICB.C

25.与编译系统相比,解释系统

A.比较简单,可移植性好

C.比较简单,可移植性差

(D)。

执行速度快

执行速度慢

26.用高级语言编写的程序经编译后产生的程序叫

A.源程序B.目标程序C.连接程序

27.词法分析器用于识别(A)o

A.字符串B.语句C.单词

B.比较复杂

D.比较简单

(B)。

D.解释程序

D.标识符

可移植性好

可移植性好

执行速度快

执行速度慢

28.编写一个计算机高级语言的源程序后,到正式上机运行之前,一般要经过

(1)编辑

(2)编译(3)连接(4)运行

A.

(1)

(2)(3)(4)B.

(1)

(2)(3)C.

(1)(3)D.

(1)(4)

29.把汇编语言程序翻译成机器可执行的目标程序的工作是由

A.编译器B.汇编器C.解释器

31.词法分析器的输出结果是(C)o

A.单词的种别编码B.单词在符号表中的位置

正规式M1和M2等价是指(C)o

M1和M2的状态数相等

M1和M2所识别的语言集相等

文法G:

StxSx|y所识别的语言是(C)o

(B)完成的。

D.预处理器

32.

A.

C.

33.

B.M1

D.M1

(B)这几步:

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

和M2的有向边条数相等和M2状态数和有向边条数相等

D.单词自身值

 

D.x*yx*

xyxB.(xyx)*C.xnyxn(n_0)

34.如果文法G是无二义的,则它的任何句子

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

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

35.构造编译程序应掌握(D)。

A.源程序B.目标语言

a(A)o

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

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

C.编译方法

D.以上三项都是

 

36.四元式之间的联系是通过(B)实现的。

A.指示器B.临时变量C.符号表

37.表达式(nAVB)A(CVD)的逆波兰表示为(B)。

A.nABVACDVB.

38.优化可生成(D)的目标代码。

A.运行时间较短

C.运行时间短但占用内存空间大

D.程序变量

AnBVCDVAC.ABVnCDVA

D.AnBVACDV

B.占用存储空间较小

D.运行时间短且占用存储空间小

39.下列(C)优化方法不是针对循环优化进行的。

A.强度削弱B.删除归纳变量

40.编译程序使用(B)区别标识符的作用域。

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

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

41.编译程序绝大多数时间花在(D)上。

A.出错处理B.词法分析

42.编译程序是对(D)。

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

43.采用自上而下分析,必须(C)。

A.消除左递归B.消除右递归

44.在规范归约中,用(B)来刻画可归约串。

A.直接短语

45.若a为终结符,则A->a

A.归约B.移进

46.间接三元式表示法的优点为

C.删除多余运算

D•代码外提

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

D.标识符的行号

C•目标代码生成

D.表格管理

C.机器语言的执行

D.高级语言的翻译

C•消除回溯

D•提取公共左因子

B.句柄

•a3为(B)项目。

C.接受

(A)。

C.最左素短语

D•素短语

D•待约

B.节省存储空间,不便于表的修改D.节省存储空间,不便于优化处理

A.采用间接码表,便于优化处理

C.便于优化处理,节省存储空间

47.基本块内的优化为(B)。

A.代码外提,删除归纳变量

C.强度削弱,代码外提

48.在目标代码生成阶段,符号表用

A.目标代码生成B.语义检查

49.若项目集Ik含有A->a•则在状态I一定是(D)。

A.LALR文法B.LR(0)文法

50.堆式动态分配申请和释放存储空间遵守

A.先请先放B.先请后放

三、填空题

1.编译程序的工作过程一般可以划分为词法分析,语法分析,语义分析,中间代码生成,代码优化等几个基本阶段

同时还会伴有__表格处理和出错处理__。

2.编译方式与解释方式的根本区别在于—是否生成目标代码

3.产生式是用于定义—语法成分__的一种书写规则。

4.设G是一个给定的文法,S是文法的开始符号,如果S->x(其中x€VT*),则称x是文法的一个—句子___。

5.自顶向下的语法分析方法的基本思想是:

从文法的__开始符号开始,根据给定的输入串并按照文法的产

生式一步一步的向下进行—直接推导,试图推导出文法的—句子____,使之与给定的输入串—匹配—。

6.常用的参数传递方式有―传地址__,传值和传名。

7.一个句型中的最左简单短语称为该句型的―句柄__。

8.对于文法的每个产生式都配备了一组属性的计算规则,称为

B•删除多余运算,删除无用赋值

D•循环展开,循环合并

C.语法检查

k时,仅当面临的输入符号

C.LR

(1)文法(D)原则。

C.后请先放

D.地址分配

a€FOLLOW(A)时,才采取“A>a•”动作的

D.SLR

(1)文法

D.任意

语义规则

 

9•一个典型的编译程序中,不仅包括—词法分析—、__语法分析—、—中间代码生成—、代码优化、目标代

码生成等五个部分,还应包括表格处理和出错处理。

10.从功能上说,程序语言的语句大体可分为—执行性―语句和—说明性―语句两大类。

11.扫描器的任务是从__源程序―中识别出一个个―■单词符号__。

12.产生式是用于定义—语法范畴—的一种书写规则。

13•语法分析是依据语言的—语法___规则进行的,中间代码产生是依据语言的—语义___规进行的。

14.语法分析器的输入是—单词符号串—,其输出是__语法单位—。

15.一个名字的属性包括—类型―和__作用域—。

16.逆波兰式ab+c+d*e-所表达的表达式为__(a+b+c)*d-e。

17.语法分析最常用的两类方法是—自上而下___和__自下而上―分析法。

18.计算机执行用高级语言编写的程序主要有两种途径:

___解释__和__编译___。

19.扫描器是—词法分析器—,它接受输入的—源程序―,对源程序进行—词法分析—并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。

20.自上而下分析法采用―移进__、归约、错误处理、—接受__等四种操作。

21.一个LR分析器包括两部分:

一个总控程序和一张分析表__。

22.后缀式abc-/所代表的表达式是a/(b-c)__。

23.局部优化是在__基本块—范围内进行的一种优化。

24.词法分析基于—正则―■文法进行,即识别的单词是该类文法的句子。

25•语法分析基于—上下文无关—文法进行,即识别的是该类文法的句子。

语法分析的有效工具是—语法树―

26.分析句型时,应用算符优先分析技术时,每步被直接归约的是__最左素短语,而应用LR分析技术时,

每步被直接归约的是—句柄__。

27.语义分析阶段所生成的与源程序等价的中间表示形式可以有—逆波兰―、—四无式表示—与—三元式表示—等。

28.按Chomsky分类法,文法按照—规则定义的形式—进行分类。

29.一个文法能用有穷多个规则描述无穷的符号串集合(语言)是因为文法中存在有―递归—定义的规则。

四、简答题

1.写一文法,使其语言是偶正整数的集合,要求:

(1)允许0打头;

(2)不允许0打头。

解:

(1)G[S]=({S,P,D,N},{0,1,2,…,9},P,S)

P:

S->PD|D

P->NP|N

D->0|2|4|6|8

N->0|1|2|3|4|5|6|7|8|9

(2)G[S]=({S,P,R,D,N,Q},{0,1,2,…,9},P,S)

P:

S->PD|P0|D

P->NR|N

R->QR|Q

D->2|4|6|8

N->1|2|3|4|5|6|7|8|9

Q->0|1|2|3|4|5|6|7|8|9

2.构造正规式相应的NFA:

1(0|1)*101

3.写出表达式(a+b*c)/(a+b)-d的逆波兰表示和三元式序列。

逆波兰表示:

abc*+ab+/d—

三元式序列:

1(*,b,c)

2(+,a,①)

3(+,a,b)

4(/,②,③)

⑤(―,④,d)

4.已知文法G[S]为:

StdAB

AtaA|a

BtBb|£

G[S]产生的语言是什么?

 

答:

G[S]产生的语言是L(G[S])={danbm|n_1,m_0}。

6.已知文法G(S)

Sta|A|(T)

Ttt,S|S

写出句子((a,a),a)的规范归约过程及每一步的句柄。

解:

句型

归约规则

句柄

((a,a),a)

STa

a

((S,a),a)

TtS

S

((T,a),a)

STa

a

((T,S),a)

Ttt,S

T,S

((S),a)

TtS

S

((T),a)

StS(T)

(T)

(S,a)

Tts

S

(T,a)

STa

a

(T,S)

Ttt,S

T,S

(T)

St(T)

(T)

S

7.写一个文法,使其语言是奇数集,且每个奇数不以0开头。

解:

文法G(N):

N^AB|B

AtAC|D

Bt1|3|5|7|9

DTB|2|4|6|8

Ct0|D

8.设文法G(S):

St(L)|aS|a

Ltl,S|S

(1)消除左递归和回溯;

(2)计算每个非终结符的FIRST和FOLLOW。

解:

St(L)|aS'

S'tS|£

LtSL'

L'tSL'|£

Ft(E)|i

(1)给出句型(T*F+i)的最右推导;

⑵给出句型(T*F+i)的短语、素短语。

解:

(1)最右推导:

E=>T->F=>(E)->(E+T)=>(E+F)->(E+i)=>(T+i)=>(T*F+i)

(2)短语:

(T*F+i),T*F+i,T*F,i

素短语:

T*F,i

10.Whilea>0Vbv0do

Begin

X:

=X+1;

ifa>0thena:

=a—1

elseb:

=b+1

End;

翻译成四元式序列。

解:

(1)(j>,a,0,5)

(2)(j,—,—,

3)

⑶(jV,b,0,

5)

(4)(j,-,-,

15)

(5)(+,X,1,

T1)

⑹(:

=,T1,

-,X)

(7)(jE0,9)

 

(8)(j,—,—,

12)

(9)(—,a,1,

T2)

(10)(:

=,T2,

a)

(11)(j,—,—,

1)

(12)(+,b,1,

T3)

(13)(:

=,T3,

b)

(14)(j,—,—,

1)

(15)

11.写出下列表达式的二地址形式的中间表示。

(1)5+6*(a+b);

(2)forj:

=1to10doa[j+j]:

=0。

答:

(1)100:

t1:

=a+b

101:

t2:

=6*t1

102:

t3:

=5+t2

(2)100:

j:

=1

101:

ifj>10gotoNEXT

102:

i:

=j+j

103:

a[i]:

=0

12.设基本块p由如下语句构成:

T0:

=3.14;

T1:

=2*T0;

T2:

=R+r;

A:

=Tl*T2;

B:

=A;

T3:

=2*T0;

T4:

=R+r;

T5:

=T3*T4;

T6:

=R-r;

B:

=T5*T6;

试给出基本块p的DAG。

 

解:

基本块p的DAG图:

13.写出表达式(a+b)/(a-b-(a+b*c)的三元序列及四元序列。

解:

(1)三元式:

1(+,a,b)

2(―,a,b)

3(/,①,②)

*,b,c)

5(+,a,④)

6(―,③,⑤)

(2)四元式:

1(+,a,b,T1)

2(―,a,b,T2)

3(/,T1,T2,T3)

*,b,c,T4)

5(+,a,T4,T5)

6(—,T3,T5,T6)

14.写一个文法使其语言为偶数集,且每个偶数不以0开头。

解:

文法G(S):

StAB|B|A0

AtAD|C

Bt2|4|6|8

Ct1|3|5|7|9|B

Dt0|C

15.设文法G(S):

Sts+aF|aF|+aF

Ft*aF|*a

(1)消除左递归和回溯;

(2)构造相应的FIRST和Follow集合。

解:

(1)

S->aFS'|+aFS'

S'->+aFS'|&

F->*aF'

F'->F|£

(2)

FIRST

(S)='

{a,+}

FOLLOW

'(S)={#}

FIRST

(S')=

{+,£}

FOLLOW

(S')={#}

FIRST

(F)=■

{*}

FOLLoW

(F)=(+,#}

FIRST

(F')=

{*

FOLLOW(

+,#}

16.简要说明语义分析的基本功能。

答:

语义分析的基本功能包括:

确定类型、类型检查、语义处理和某些静态语义检查。

17.考虑文法G[S]:

St(T)|a+S|a

Ttt,S|S

消除文法的左递归及提取公共左因子。

解:

消除文法G[S]的左递归:

St(T)|a+S|a

TtST'

T't,ST'|£

提取公共左因子:

St(T)|aS'

S't+s|£

TtST'

T't,ST'|£

18.试为表达式w+(a+b)*(c+d/(e-10)+8)写出相应的逆波兰表示。

解:

wab+cde10-/+8+*+

19.按照三种基本控制结构文法将下面的语句翻译成四元式序列:

while(A

{

if(A>1)C=C+1;

elsewhile(A

A=A+2;

}。

解:

该语句的四元式序列如下(其中E1、E2和E3分别对应AVCABVD、A》1和A

高):

100(j<,A,C,102)

101(j,亠113)

102(j<,B,D,104)

103(j,_,_,113)

104(j=,A,1,106)

105(j,_,_,108)

106(+,C,1,C)

107(j,_,_,112)

108(jW,A,D,110)

109(

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > IT计算机 > 计算机软件及应用

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1