.名词解释:   
1)前缀
答:前缀——是指符号串任意首部。
2)可归前缀
答:可归前缀——是指规范句型的一个前缀,这种前缀包含句柄且不含句柄之后的任何符号。
3)活前缀
答:活前缀——规范句型的一个前缀,这种前缀不含句柄之后的任何符号。 
          或给定文法规范句型的可归前缀的任意首部。
4)简单短语
答:简单短语——G[Z]是给定文法,w=xuyV+,为该文法的句型,如果满足下面两个条件:
Z xUy    Uu
            则称句型xuy 中的子串u是句型xuy的简单短语。
5)扫描遍
答:扫描遍——指编译程序对源程序或中间代码程序从头到尾扫描一次。
6)句柄
答:句柄——给定句型中的最左简单短语就是句柄
7)句型
答:句型——G是一个给定的文法,S是文法的开始符号,如果Sx(其中xV*),则称x是文法的一个句型。
8)句子
答:句子——G是一个给定的文法,S是文法的开始符号,如果S  x(其中xVT*),则称x是文法的一个句子。
9)非终结符
答:非终结符出现在文法产生式的左部且能派生出符号或符号串的那些符号称为终结符号。
10)终结符
答:终结符——出现在文法产生式的右部且不能派生出符号或符号串的那些符号称为终结符号。
11)属性文法
答:一个属性文法形式的定义为一个三元组AGAG=GVE)。
      其中G为一个上下文无关文法;V为属性的有穷集;E为一组语义规则。
12)语法制导翻译
答:语法制导翻译——语法制导翻译就是在语法分析的过程中,当进行推导或归约时同步完成附加在所使用的产生式上的语义规则描述的动作,从而实现语义处理。
13)后缀式
答:后缀式——一种把运算量(操作数)写在前面,把算符写在后面(后缀)的表示法。
14)短语
答:短语——G[Z]是给定文法,w=xuyV+,为该文法的句型,如果满足下面两个条件:
Z xUy    U u
            则称句型xuy 中的子串u是句型xuy的短语。
或:句型语法树的全部子树的叶从左到右排列起来构成的符号串均是句型的短语。
15)基本块
答:基本块——源程序或者中间代码程序中只有一个入口和一个出口的顺序执行的代码段。
16)语义规则
答:对于文法的每个产生式都配备了一组属性的计算规则,称为语义规则。
17)语法分析
答:语法分析——按文法的产生式识别输入的符号串是否为一个句子的分析过程。
18)四元式
答:四元式——是一个带有四个域的记录结构,这四个域分别称为操作符域、左运算对象域、右运算对象域及运算结果域。
二.简答题:
1) 什么是句子? 什么是语言?
解答:句子——G是一个给定的文法,S是文法的开始符号,如果S  x(其中xVT*),则称x是文法的一个句子。
语言——语言是句子的集合。
——G[S]是给定文法,则由文法G所定义的语言L(G)可描述为:L(G){xSx,xVT*}
2) DFANFA有何区别 ?
解答:DFANFA的区别表现为两个方面:一是NFA可以有若干个开始状态,而DFA仅只有一个开始状态。另一方面,DFA的映象M是从K×∑到K,而NFA的映象M是从K×∑到K的子集,即映象M将产生一个状态集合(可能为空集),而不是单个状态。
3) 自顶向下的语法分析方法的基本思想是什么?
解答:从文法的开始符号开始,根据给定的输入串并按照文法的产生式一步一步的向下进行直接推导,试图推导出文法的句子,使之与给定的输入串匹配。
4) 一个上下文无关文法G包括哪四个组成部分?
解答:一组非终结符号,一组终结符号,一个开始符号,以及一组产生式。
5) 在自底向上的语法分析方法中,分析的关键是什么?
解答:关键是寻句柄。
6) 在自顶向下的语法分析方法中,分析的关键是什么?
解答:关键是选择候选式。
7) 编译程序中语法分析器接收以什么为单位的输入?
解答: 接收以单词为单位的输入。
8) 若一个文法是递归的,则它所产生的语言的句子是可枚举的吗?
解答: 它所产生的语言的句子不是可枚举的,而是无穷多个。
9) 编译程序生成的目标程序是不是一定是机器语言的程序?
解答:不一定是机器语言的程序。
10) 词法分析器是用于做什么的?
解答:源程序能直接执行吗词法分析器是用于识别单词的。
11) “用高级语言书写的源程序都必须通过编译,产生目标代码后才能投入运行”这种说法正确吗?
解答: 不正确。
12) 把汇编语言程序翻译成机器可执行的目标程序的工作是由什么完成的?
解答: 由汇编器(汇编程序)完成的。
14)图示运行时存储空间的划分(分为哪几个区)。
解答一般分为静态区和动态区:
            程序代码区、静态数据区、栈区和堆区
15)词法分析的主要任务是什么?
解答:词法分析器的任务是对构成源程序的字符串从左到右逐个字符逐个字符地进行扫描,依次把它们识别为一个一个具有独立意义的单词,并确定其属性,再转换为长度统一的属性字并输出。
16)常用的中间语言种类有哪几种?
解答: 常用的中间语言种类有逆波兰表示、三元式、四元式和树形表示。
17)文法G所描述的语言是什么的集合?
解答:是由文法的开始符号推出的所有终结符串的集合。或说是句子的集合。
18)乔姆斯基把文法分为四种类型,即0型、1型、2型、3型。其中2型文法叫什么?
解答: 2型文法叫上下文无关文法。
19)编译程序是一种解释程序吗?还是什么程序?
解答:编译程序是一种翻译程序。
20)按逻辑上划分,编译程序第二步工作是什么?
解答: 编译程序第二步工作是语法分析。
21)源程序是用高级语言编写的,目标程序是机器语言程序或汇编语言程序 ,则其翻译程序称为什么?
解答: 其翻译程序称为编译程序。
22)编译方式与解释方式的根本区别为什么?
解答:编译方式与解释方式的根本区别在于是否生成目标代码。
25)语法分析的任务是什么?
解答:语法分析的任务是识别给定的终结符串是否为给定文法的句子。
27)文法等价的定义是什么?
解答: G1G2是给定的文法,如果有LG1= LG2),则称G1G2等价。
28)在语法分析处理中,FIRST集合、FOLLOW集合、SELECT集合均是什么集合?
解答: 均是终结符集。
29)通常一个编译程序中应包括哪七个部分?
解答: 通常一个编译程序中应包含词法分析,语法分析,语义分析与中间代码生成,代码优化,目标代码生成以及表格处理和出错处理等七个部分。
32)如果编译程序生成的目标程序是汇编语言程序,则源程序的执行分为哪三个阶段?
解答: 源程序的执行分为三个阶段: 编译阶段,汇编阶段和运行阶段。
34)说明下面文法G[S]是二义性文法:SSaS|SbS|cSd|eS|f
解答:fafbf是文法G[S]的一个句子,并且有两个不同的最右推导。
1S => SaS => SaSbS => SaSbf=> Safbf=> fafbf
    2S => SbS => Sbf=> SaSbf => Safbf=> fafbf
因此说明此文法有二义性。
36)代码优化的主要目标是什么?
解答: 代码优化的主要目标是如何提高目标程序的运行速度和如何减少目标程序运行时所需的空间。
37)写一个文法,使其语言是无符号二进制实数(不含指数)。
解答:文法G(N)
       NL.L|L
       LLB|B
       B0|1
三.计算题
1)消除下列文法G[A]的左递归。
EE-TT
TT/FF
F( E )i
解答:消除文法G[E]的左递归后得到:
ETE
E’→-T E′∣ε
TFT
T’→/FT′∣ε
F( E )i
2) 消除下列文法G[A]的左递归。
AAaBB
BBbCC
CeDD
D(A)d
解答:消除文法G[A]的左递归后得到:
A BAˊ
      Aˊ→aBAˊ∣ε
B CBˊ
Bˊ→bcBˊ∣ε
CeDD
D(A)d
3)给定下列自动机:
把此自动机转换为确定自动机DFA
解答:  有状态矩阵如图:
从而可得DFA如图:
4)正规式(a|b*a(a|b) 构造一个等价的有限自动机。
解答:
四.设计题
1)给定文法G[S] 及相应翻译方案为:
1SS          {print:a}
2Sr D        {print:b}
3DDi      {print:c}
4Di          {print:d}
a. chomsky分类法,文法G属于哪一型文法?
b. 符号串ri,i,i是不是该文法的一个句型,请证实。
c. 若是句型,写出该句型的所有短语、简单短语,以及句柄。
d. 构造识别该文法的活前缀的DFA
e. 判断该文法是LR0)还是SLR1),并构造其相应的语法分析表。
f. 对于ri,i,i这个输入符号串,经该翻译方案翻译后的输出是什么?
解答:
a文法G属于2(上下文无关)文法。
b.符号串r i,i,i是该文法的一个句型。
证:SSrDrDi rDii r iii,得证。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。