第一章
1、将编译程序分成若干个“遍”是为了 。 b.使程序的结构更加清晰 2、构造编译程序应掌握 。 a.源程序
b.目标语言
c.编译方法
3、变量应当 。
c.既持有左值又持有右值
4、编译程序绝大多数时间花在 上。 d.管理表格
5、 不可能是目标代码。 d.中间代码
6、使用 可以定义一个程序的意义。 a.语义规则
7、词法分析器的输入是 。 b.源程序
8、中间代码生成时所遵循的是- 。 c.语义规则
9、编译程序是对 。 d.高级语言的翻译
10、语法分析应遵循 。 c.构词规则 二、多项选择题
1、编译程序各阶段的工作都涉及到 。 b.表格管理
c.出错处理
2、编译程序工作时,通常有 阶段。 a.词法分析 三、填空题
b.语法分析
c.中间代码生成 e.目标代码生成
1、解释程序和编译程序的区别在 于是否生成目标程序 。
2、编译过程通常可分为5个阶段,分别是 词法分析 、语法分析中间代码生成 、代码优化和目标代码生成。
3、编译程序工作过程中,第一段输入是 源程序 ,最后阶
段的输出为 标代码生成 程序。
4、编译程序是指将 源程序 程序翻译成 目标语言 程序的程序。
一、单项选择题
1、文法G:S→xSx|y所识别的语言是 。
a. xyx
b. (xyx)*
c. xnyxn(n≥0)
d. x*yx*
2、文法G描述的语言L(G)是指 。
α , α∈VT*} a. L(G)={α|S+?
*α, α∈V*} b. L(G)={α|S?T
*α,α∈(V∪V*)} d. L(G)={α|S?+ α, α∈(V∪V*)} c. L(G)={α|S?TNTN
3、有限状态自动机能识别 。
a. 上下文无关文法 c.正规文法
b. 上下文有关文法 d. 短语文法
4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立 。
a. 若f(a)>g(b),则a>b c. a~b都不一定成立
b.若f(a) 5、如果文法G是无二义的,则它的任何句子α 。 a. 最左推导和最右推导对应的语法树必定相同 b. 最左推导和最右推导对应的语法树可能不同 c. 最左推导和最右推导必定相同 d. 可能存在两个不同的最左推导,但它们对应的语法树相同 6、由文法的开始符经0步或多步推导产生的文法符号序列是 。 a. 短语 b.句柄 c. 句型 d. 句子 7、文法G:E→E+T|T T→T*P|P P→(E)|I 则句型P+T+i的句柄和最左素短语为 。 a.P+T和i b. P和P+T c. i和P+T+i d.P和T 8、设文法为:S→SA|A A→a|b 则对句子aba,下面 是规范推导。 a. S?SA?SAA?AAA?aAA?abA?aba b. S?SA?SAA?AAA?AAa?Aba?aba c. S?SA?SAA?SAa?Sba?Aba?aba d. S?SA?Sa?SAa?Sba?Aba?aba 9、文法G:S→b|∧(T) T→T,S|S 则FIRSTVT(T) 。 a. {b,∧,(} b. {b,∧,)} c.{b,∧,(,,} d.{b,∧,),,} 10、产生正规语言的文法为 。 a. 0型 b. 1型 c. 2型 d. 3型 11、采用自上而下分析,必须 。 a. 消除左递归 b. 消除右递归 c. 消除回溯 d. 提取公共左因子 12、在规范归约中,用 来刻画可归约串。 a. 直接短语 b. 句柄 c. 最左素短语 d. 素短语 13、有文法G:E→E*T|T T→T+i|i 句子1+2*8+6按该文法G归约,其值为 。 a. 23 B. 42 c. 30 d. 17 14、规范归约指 。 a. 最左推导的逆过程 b. 最右推导的逆过程 c. 规范推导 d. 最左归约的逆过程 二、多项选择题 1、下面哪些说法是错误的 。 a. 有向图是一个状态转换图 c.有向图是一个DFA b. 状态转换图是一个有向图 d.DFA可以用状态转换图表示 2、对无二义性文法来说,一棵语法树往往代表了 。 a. 多种推导过程 d.仅一种推导过程 b. 多种最左推导过程 e.一种最左推导过程 c.一种最左推导过程 3、如果文法G存在一个句子,满足下列条件 之一时,则称该文法是二义文法。 a. 该句子的最左推导与最右推导相同 b. 该句子有两个不同的最左推导 c. 该句子有两棵不同的最右推导 d. 该句子有两棵不同的语法树 e.该句子的语法树只有一个 4、有一文法G:S→AB A→aAb|ε B→cBd|ε b. {anbncmdm|n,m>0} d. {anbncmdm|n,m≥0} 它不产生下面 集合。 a. {anbmcndm|n,m≥0} c. {anbmcmdn|n,m≥0} e. {anbncndn|n≥0} 5、自下而上的语法分析中,应从 开始分析。 a. 句型 b. 句子 c. 以单词为单位的程序 d. 文法的开始符 e. 句柄 6、对正规文法描述的语言,以下 有能力描述它。 a.0型文法 b.1型文法 c.上下文无关文法 d.右线性文法 e.左线性文法 三、填空题 1、文法中的终结符和非终结符的交集是 。词法分析器交给语法分析器的文法符号一定是 ,它一定只出现在产生式的 部。 2、最左推导是指每次都对句型中的 非终结符进行扩展。 3、在语法分析中,最常见的两种方法一定是 分析法,另一是 分析法。 4、采用 语法分析时,必须消除文法的左递归。 5、 树代表推导过程, 树代表归约过程。 6、自下而上分析法采用 、归约、错误处理、 等四种操作。 7、Chomsky把文法分为 种类型,编译器构造中采用 和 文法,它们分别产生 和 语言,并分别用 和 自动机识别所产生的语言。 四、判断题 1、文法 S→aS|bR|ε描述的语言是(a|bc)* R→cS 2、在自下而上的语法分析中,语法树与分析树一定相同。 3、二义文法不是上下文无关文法。 4、语法分析时必须先消除文法中的左递归。 5、规范归约和规范推导是互逆的两个过程。 ( ) ( ) ( ) ( ) ( ) ( ) 6、一个文法所有句型的集合形成该文法所能接受的语言。 五、简答题 1、句柄 六、问答题 1、给出上下文无关文法的定义。 2、文法G[S]: S→aSPQ|abQ QP→PQ bP→bb bQ→bc cQ→cc (1)它是Chomsky哪一型文法? (2)它生成的语言是什么? 3、按指定类型,给出语言的文法。 L={aibj|j>i≥1}的上下文无关文法。 4、有文法G:S→aAcB|Bd 2、素短语 3、语法树 4、归约 5、推导 A→AaB|c B→bScA|b (1)试求句型aAaBcbbdcc和aAcbBdcc的句柄; (2)写出句子acabcbbdcc的最左推导过程。 5、对于文法G[S]: S→(L)|aS|a L→L, S|S (1)画出句型(S,(a))的语法树。(2)写出上述句型的所有短语、直接短语、句柄和素短语。 6、考虑文法G[T]: T→T*F|F F→F↑P|P P→(T)|i 证明T*P↑(T*F)是该文法的一个句型,并指出直接短语和句柄。 单选[解答] 1、选c。 2、选a。 3、选c。 4、虽然a与b没有优先关系,但构造优先函数后,a与b就一定存在优先关系了。所以,由f(a)>g)(b)或f(a) 5、如果文法G无二义性,则最左推导是先生长右边的枝叶:对于d,如果有两个不同的是了左推导,则必然有二义性。故选a。 6、选c。 7、由图2-8-1的语法树和优先关系可以看出应选b。 8、规范推导是最左推导,故选d。 9、由T→T,?和T→(? 得FIRSTVT(T))={(,,)}; 由T→S得FIRSTVT(S)?FIRSTVT(T),而FIRSTVT(S)={b,∧,(};即 FIRSTVT(T)={b,∧,(,,}; 因此选c。 E + F E + T P T i P #<·+·>+<·i·># 图2-8-1 句型P+T+I的语法及优先关系 E 10、d 11、c 12、b 13、b 14、b 多选解答 1、e、a、c 2、a、c、e 3、b、c、d 4、a、c 5、b、c 6、a、b、c、d、e