编译原理期末总复习题含答案_第1页
编译原理期末总复习题含答案_第2页
编译原理期末总复习题含答案_第3页
编译原理期末总复习题含答案_第4页
编译原理期末总复习题含答案_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、-. z.第八节 习题一、单项选择题1、将编译程序分成假设干个“遍是为了b。a提高程序的执行效率b使程序的构造更加清晰c利用有限的机器内存并提高机器的执行效率d利用有限的机器内存但降低了机器的执行效率2、构造编译程序应掌握d。a源程序b目标语言c编译方法d以上三项都是3、变量应当c。a持有左值b持有右值c既持有左值又持有右值d既不持有左值也不持有右值 4、编译程序绝大多数时间花在b上。a出错处理b词法分析c目标代码生成d管理表格5、d不可能是目标代码。a汇编指令代码b可重定位指令代码c绝对指令代码d中间代码6、使用a可以定义一个程序的意义。a语义规则b词法规则c产生规则d词法规则7、词法分析器

2、的输入是a。a单词符号串b源程序c语法单位d目标程序8、中间代码生成时所遵循的是-d。a语法规则b词法规则c语义规则d等价变换规则9、编译程序是对d。a汇编程序的翻译b高级语言程序的解释执行c机器语言的执行d高级语言的翻译10、语法分析应遵循b。a语义规则b语法规则c构词规则d等价变换规则解答1、将编译程序分成假设干个“遍是为了使编译程序的构造更加清晰,应选b。2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,应选d。3、对编译而言,变量既持有左值又持有右值,应选c。4、编译程序打交道最多的就是各种表格,因此选d。5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,

3、因此不是目标代码的只能选d。6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。因此选a。 7、b 8、c 9、d 10、c二、多项选择题1、编译程序各阶段的工作都涉及到bc。a语法分析b表格管理c出错处理d语义分析e词法分析2、编译程序工作时,通常有abce阶段。a词法分析b语法分析语义分析?c中间代码生成 中间代码优化d语义检查e目标代码生成解答1b、c 2. a、b、c、e三、填空题1、解释程序和编译程序的区别在于是否生成目标程序解释不产生目标程序,边翻译边执行。2、编译过程通常可分为5个阶段,分别是词法分析、语法分析

4、语义分析中间代码生成、代码优化和目标代码生成。3、编译程序工作过程中,第一段输入是源程序,最后阶段的输出为目标程序程序。4、编译程序是指将源程序程序翻译成目标程序程序的程序。解答 是否生成目标程序 2、词法分析 中间代码生成 3、源程序目标代码生成4、源程序 目标语言一、单项选择题1、文法G:S*S*|y所识别的语言是c。a.*y*b.(*y*)*c.*ny*n(n0)d.*y*是指多个*2、文法G描述的语言L(G)是指ab。a. L(G)=|Seq o(sup 3(+),sdo 1(), VT*b. L(G)=|Seq o(sup 3(*),sdo 1(), VT*c. L(G)=|Seq

5、o(sup 3(*),sdo 1(),(VTVN*)d. L(G)=|Seq o(sup 3(+),sdo 1(),(VTVN*)3、有限状态自动机能识别。a. 上下文无关文法b. 上下文有关文法c.正规文法d. 短语文法4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立。a. 假设f(a)g(b),则abb.假设f(a)g(b),则ag)(b)或f(a)g(b)并不能判定原来的a与b之间是否存在优先关系:应选c。5、如果文法G无二义性,则最左推导是先生长右边的枝叶:对于d,如果有两个不同的是了左推导,则必然有二义性。应选a。6、选c。7、由图2-8-1的语法树和优先关系可以看出应选

6、b。EE + FE + T PT iP #+#图2-8-1 句型P+T+I的语法及优先关系8、规*推导是最左推导,应选d。9、由TT,和T( 得FIRSTVT(T)=(,,); 由TS得FIRSTVT(S)FIRSTVT(T),而FIRSTVT(S)=b,(;即 FIRSTVT(T)=b,(,,; 因此选c。 10、d 11、c 12、b 13、b 14、b二、多项选择题1、下面哪些说法是错误的。a. 有向图是一个状态转换图b. 状态转换图是一个有向图c.有向图是一个DFAd.DFA可以用状态转换图表示2、对无二义性文法来说,一棵语法树往往代表了。a. 多种推导过程b. 多种最左推导过程c.一

7、种最左推导过程d.仅一种推导过程e.一种最左推导过程3、如果文法G存在一个句子,满足以下条件之一时,则称该文法是二义文法。a. 该句子的最左推导与最右推导一样b. 该句子有两个不同的最左推导c. 该句子有两棵不同的最右推导d. 该句子有两棵不同的语法树 e.该句子的语法树只有一个4、有一文法G:SAB AaAb| BcBd|它不产生下面集合。a. anbmdm|n,m0b. anbncmdm|n,m0c. anbmcmdn|n,m0d. anbncmdm|n,m0e. anbndn|n05、自下而上的语法分析中,应从开场分析。a. 句型b. 句子c. 以单词为单位的程序d. 文法的开场符e.

8、句柄6、对正规文法描述的语言,以下有能力描述它。a.0型文法b.1型文法 c.上下文无关文法 d.右线性文法 e.左线性文法解答 1、e、a、c 2、a、c、e 3、b、c、d 4、a、c 5、b、c 6、a、b、c、d、e 三、填空题1、文法中的终结符和非终结符的交集是。词法分析器交给语法分析器的文法符号一定是,它一定只出现在产生式的部。2、最左推导是指每次都对句型中的非终结符进展扩展。3、在语法分析中,最常见的两种方法一定是分析法,另一是分析法。4、采用语法分析时,必须消除文法的左递归。5、树代表推导过程,树代表归约过程。6、自下而上分析法采用、归约、错误处理、等四种操作。7、Chomsk

9、y把文法分为种类型,编译器构造中采用和文法,它们分别产生和语言,并分别用和自动机识别所产生的语言。解答 1、空集 终结符 右 2、最左 3、自上而上 自下而上 4、自上而上 5、语法 分析 6、移进 承受 7、4 2 型 3型 上下文无关语言 正规语言 下推自动机 有限四、判断题1、文法 SaS|bR|描述的语言是(a|bc)*( ) RcS2、在自下而上的语法分析中,语法树与分析树一定一样。 3、二义文法不是上下文无关文法。 4、语法分析时必须先消除文法中的左递归。 5、规*归约和规*推导是互逆的两个过程。 6、一个文法所有句型的集合形成该文法所能承受的语言。 解答 1、对 2、错 3、错

10、4、错 5、错 6、错五、简答题1、句柄2、素短语3、语法树4、归约5、推导解答 1、句柄:一个句型的最左直接短语称为该句型的句柄。2、素短语:至少含有一个终结符的素短语,并且除它自身之外不再含任何更小的素短语。3、语法树:满足下面4个条件的树称之为文法GS的一棵语法树。每一终结均有一标记,此标记为VNVT中的一个符号;树的根结点以文法GS的开场符S标记;假设一结点至少有一个直接后继,则此结点上的标记为VN中的一个符号;假设一个以A为标记的结点有K个直接后继,且按从左至右的顺序,这些结点的标记分别为*1,*2,*K,则A*1,*2,*K,必然是G的一个产生式。4、归约:我们称直接归约出A,仅当

11、A 是一个产生式,且、(VNVT)*。归约过程就是从输入串开场,反复用产生式右部的符号替换成产生式左部符号,直至文法开场符。5、推导:我们称A直接推出,即A,仅当A 是一个产生式,且、(VNVT)*。如果12n,则我们称这个序列是从1至2的一个推导。假设存在一个从1n的推导,则称1可推导出n。推导是归约的逆过程。六、问答题1、给出上下文无关文法的定义。解答一个上下文无关文法G是一个四元式VT,VN,S, P,其中:VT是一个非空有限集,它的每个元素称为终结符号;VN是一个非空有限集,它的每个元素称为非终结符号,VTVN=;S是一个非终结符号,称为开场符号;P是一个产生式集合有限,每个产生式的形

12、式是P,其中,PVN,(VTVN)*。开场符号S至少必须在*个产生式的左部出现一次。2、文法GS: SaSPQ|abQ QPPQ bPbb bQbc cQcc1它是Chomsky哪一型文法?2它生成的语言是什么?解答 1由于产生式左部存在终结符号,且所有产生式左部符号的长度均小于等于产生式右部的符号长度,所以文法GS是Chomsky1型文法,即上下文有关文法。2按产生式出现的顺序规定优先级由高到低否则无法推出句子,我们可以得到: SabQabc SaSPQaabQPQaabPQQaabbQQaabbcQaabbcc SaSPQaaSPQPQaaabQPQPQaaabPQQPQaaabPQPQQ

13、aaaPPQQQaaabbPqqqaaabbQQQaaabbbcQQaaabbbccQaaabbbccc于是得到文法GS生成的语言L=anbn|n13、按指定类型,给出语言的文法。L=aibj|ji1的上下文无关文法。【解答】1由L=aibj|ji1知,所求该语言对应的上下文无关文法首先应有SaSb型产生式,以保证b的个数不少于a的个数;其次,还需有SSb或SbS型的产生式,用以保证b的个数多于a的个数;也即所求上下文无关文法GS为:GS:SaSb|Sb|b4、有文法G:SaAcB|BdAAaB|cBbScA|b1试求句型aAaBcbbdcc和aAcbBdcc的句柄;2写出句子acabcbbd

14、cc的最左推导过程。【解答】1分别画出对应两句型的语法树,如图2-8-2所示句柄:AaB Bd Sa A c B AaB b S c AB d cb(a)S a A c BB S c AB d c(b)图2-8-2 语法树2句子acabcbbdcc的最左推导如下: SaAcBaAaBcBacaBcBacabcBacabcbScAacabcbBdcAacabcbbdcAacabcbbdcc5、对于文法GS: SL|aS|aLL, S|S1画出句型S,a的语法树。2写出上述句型的所有短语、直接短语、句柄和素短语。S L L , SS ( L ) S a图2-8-3 句型S,a的语法树【解答】1句型

15、S,a的语法树如图2-8-3所示2由图2-8-3可知:短语:S、a、(a)、S,(a)、(S,(a);直接短语:a、S;句柄:S;素短语:素短语可由图2-8-3中相邻终结符之间的优先关系求得,即;# ,a #因此素短语为a。6、考虑文法GT:TT*F|FFFP|PPT|iTT * FF PP T T * F图2-8-4 句型T*PT*F的语法树证明T*PT*F是该文法的一个句型,并指出直接短语和句柄。【解答】首先构造T*PT*F的语法树如图2-8-4所示。由图2-8-4可知,T*PT*F是文法GT的一个句型。直接短语有两个,即P和T*F;句柄为P。一、单项选择题1、词法分析所依据的是。a. 语

16、义规则b. 构词规则c. 语法规则d. 等价变换规则2、词法分析器的输出结果是。a. 单词的种别编码b. 单词在符号表中的位置c. 单词的种别编码和自身值d. 单词自身值3、正规式M1和M2等价是指。a. M1和M2的状态数相等b. M1和M2的有向弧条数相等c. M1和M2所识别的语言集相等 d. M1和M2状态数和有向弧条数相等4、状态转换图见图3-6-1承受的字集为。 0 1 0图3-6-1Y*a. 以 0开头的二进制数组成的集合 b. 以0结尾的二进制数组成的集合c. 含奇数个0的二进制数组成的集合 d. 含偶数个0的二进制数组成的集合5、词法分析器作为独立的阶段使整个编译程序构造更加

17、简洁、明确,因此,。a. 词法分析器应作为独立的一遍 b. 词法分析器作为子程序较好c. 词法分析器分解为多个过程,由语法分析器选择使用 d. 词法分析器并不作为一个独立的阶段解答 1、b 2、c 3、c 4、d 5、b二、多项选择题1、在词法分析中,能识别出。a. 根本字b. 四元式c. 运算符d. 逆波兰式e. 常数2、令=a,b,则上所有以b开头,后跟假设干个ab的字的全体对应的正规式为。a.b(ab)*b. b(ab)+c.(ba)*bd. (ba)+be. b(a|b)解答 1、a、c、e 2、a、b、d三、填空题1、确定有限自动机DFA是的一个特例。2、假设二个正规式所表示的一样,

18、则认为二者是等价的。3、一个字集是正规的,当且仅当它可由所。解答 1、NFA 2、正规集 3、DFANFA所识别四、判断题1、一个有限状态自动机中,有且仅有一个唯一终态。 2、设r和s分别是正规式,则有Lr|s=L(r)|L(s)。 3、自动机M和M的状态数不同,则二者必不等价。 4、确定的自动机以及不确定的自动机都能正确地识别正规集。 5、对任意一个右线性文法G,都存在一个NFA M,满足L(G)=L(M)。 6、对任意一个右线性文法G,都存在一个DFA M,满足L(G)=L(M)。 7、对任何正规表达式e,都存在一个NFA M,满足L(G)=L(e)。 8、对任何正规表达式e,都存在一个D

19、FA M,满足L(G)=L(e)。 解答 1 、2、3、错 4、5、6、7、8、正确五、基此题1、设M*,y, a,b, f,*,y为一非确定的有限自动机,其中f定义如下:f*,a*,y f*,byfy,a fy,b*,y 试构造相应确实定有限自动机M。解答:对照自动机的定义M=(S,f,S0,Z),由f的定义可知f(*,a)、f(y,b)均为多值函数,所以是一非确定有限自动机,先画出NFA M相应的状态图,如图3-6-2所示。 a a b b b图3-6-2 NFA M*Y用子集法构造状态转换矩阵表3-6-3所示。IIaIb*,yyy*,y*,y*,y*,y将转换矩阵中的所有子集重新命名而形

20、成表3-6-4所示的状态转换矩阵。表3-6-4 状态转换矩阵ab02112222 a a,b b b图3-6-5 DFA M021即得到M=0,1,2, a,b, f,0, 1,2,其状态转换图如图3-6-5所示。 a a,b b图3-6-6 化简后的DFA M01将图3-6-5的DFA M最小化。首先,将M的状态分成终态组1,2与非终态组0;其次,考察1,2。由于1,2a=1,2b=21,2,所以不再将其划分了,也即整个划分只有两组0,1,2:令状态1代表1,2,即把原来到达2的弧都导向1,并删除状态2。最后,得到如图3-6-6所示化简DFA M。2、对给定正规式b*d|adb|ab+,构造

21、其NFA M; aadb*b*(d|ad)(b|ab)(b|ab)*Y*123Y*4135Y678(d|ad)(b|ab)(b|ab)*2dbadabb|abb*4135Y2bdbbabb图3-6-7 的NFA M解答:首先用A+=AA*改造正规式得:b*(d|ad)(b|ab)(b|ab)*;其次,构造该正规式的NFA M,如图3-6-7所示。1、 构造下面文法的LL1分析表。D TLT int | realL id RR, id R | 解答: LL1分析表见表4-3-1分析 虽然这个文法很简单,我们还是从求开场符号集合和后继符号集合开场。 FIRSTD=FIRSTT=int, realF

22、OLLOWD=FOLLOWL=#FIRSTL=id FOLLOWT=idFIRSTR=,, FOLLOWR=#有了上面每个非终结符的FIRST集合,填分析表时要计算一个产生式右部的FIRST就不是件难事了。填表时唯一要小心的时,是产生式R右部的一个开场符号,而#在FOLLOWR中,所以R填在输入符号#的栏目中。表4-3-1 LL1分析表非终结符输入符号int realid,#DDTLDTLTTintTrealLLid RRR,id RR2、 下面文法GS是否为LL1文法?说明理由。SA B | P Q *A * y B b cP d P | Q a Q | 解答: 该文法不是LL1文法,见下面

23、分析中的说明。分析 只有三个非终结符有两个选择。 1、P的两个右部d P 和 的开场符号肯定不相交。2、Q的两个右部a Q 和 的开场符号肯定不相交。3、对S来说,由于* FIRST(A B),同时也有* FIRST(P Q *)因为P和Q都可能为空。所以该文法不是LL1文法。3、 设有以下文法: GS:SaAbDe|d ABSD|e BSAc| cD| DSe| 1求出该文法的每一个非终结符U的FOLLOW集。2该文法是LL1文法吗?3构造CS的LL1分析表。解答: 1求文法的每一个非终结符U的FOLLOW集的过程如下:因为: S是识别符号,且有ABSD、BSAc、DSe,所以FOLLOWS

24、应包含FIRST(D)FIRST(Ac)FIRST(e)#=a,da,d,c,ee#=a,c,d,e#又因为ABSD和D,所以FOLLOW中还包含FOLLOW(A)。因为SaAbDe和BSAc,所以FOLLOWA=FIRSTbDeFIRSTc=b,c综合、得FOLLOWS=a,d,c,e,#a,b,c,d,e,#因为ABSD,所以FOLLOWB=FIRSTSD=a,d因为SaAbDe | d、ABSD| e和BSAc | cD,所以FOLLOWD=FIRSTeFOLLOWAFOLLOWB=eb,ca,d=a,b,c,d,e2GS不是LL1文法。因为产生式BSAc|cD| 中FIRSTSAcFO

25、LLOWB=a,d3构造GS的LL1分析表。按照LL1分析表的构造算法构造方法GS的LL1分析表如表4-3-2所示。表4-3-2 GS的LL1分析表abcde#SaAbDedABSDBSDBSDeBSac/cDSac/DSe/Se/4、 将文法GV改造成为LL(1)的。 GV:VN|NE EV|V+E Ni解答: 对文法GV提取公共左因子后得到文法: GV:VNAA|EEVBB|+ENi求出文法GV中每一个非终结符号的FIRST集:FIRST(V)=iFIRST(A)=,FIRST(E)=iFIRST(B)=+,FIRST(N)=i求出文法GV中每一个非终结符号的FOLLOW集:FOLLOW(

26、V)=#FIRST(B)FOLLOW(E)=#,+,FOLLOW(A)= FOLLOW(V)=+,#FOLLOW(E)= FIRST()FOLLOW(B)= FIRST()FOLLOW(E)=FOLLOW(B)= FOLLOW(E)= FOLLOW(N)= FIRST(A)FOLLOW(V)=,+,#可以看到,对文法GV的产生式A|E,有FIRST(E)FOLLOW(A)=+,#= 对产生式B|+E,有FIRST(+E)FOLLOW(B)=+= 而文法的其他产生式都只有一个不为的右部,所以文法GV是LL(1)文法。5、文法:GA:AaAa|1该文法是LL1文法吗?为什么?2假设采用LL1方法进

27、展语法分析,如何得到该文法的LL1分析表?3假设输入符号串“aaaa,请给出语法分析过程。解答:1因为产生式AaAa| 有空产生式右部,而FOLLOW(A)=#FIRST(a)=a, #造成 FIRST(A)FOLLOW(A)=A, a, #所以该文法不是LL1文法。2假设采用LL1方法进展语法分析,必须修改该文法。因该文法产生偶数可以为0个a,所以得到文法GA:AaaA|此时对产生式AaaA|, 有 FOLLOW(A)=#FOLLOW(A)=#,因而FIRST(A)FOLLOW(A)=a, #=所以文法GA是LL1文法,按LL1分析表构造算法构造该文法的LL1分析表如表4-3-3所示。表4-

28、3-3文法GA的LL(1)分析表A#AAaaAA3假设采用LL(1)方法进展语法分析,对符号串“aaaa的分析过程如表4-3-4所示。 表4-3-4对符号串“aaaa的分析过程步骤分析栈输入串产生式/动作1#Aa a a a #AaaA2#A a aa a a a #匹配3#A aa a a #匹配4#Aa a #AaaA5#A a aa a #匹配6#A aa#匹配7#A#A8#承受第七节 习题设有文法GS为:Sa|b|(A)ASdA|S完成以下算符优先关系表,见表5-7-1,并判断GS是否为算符优先文法。表5-7-1 算符优先关系表ab()d#ab()d#2给出句型SdSdS的短语、简单短

29、语、句柄、素短语和最左素短语。3给出输入串adb#的分析过程。解答: 1先求文法GS的FIRSTVT集和LASTVT集:由Sa|b|(A)得:FIRSTVT(S)=a,b,( );由ASd得:FIRSTVT(A)=d;又由AS得:FIRSTVT(S) FIRSTVT(A),即FIRSTVT(A)=d,a,b,(;由Sa|b|(A)得;LASTVT(S)=a,b,;由AdA得:LASTVT(A)=d,又由AS得:LASTVT(S) LASTVT(A),即LASTVT(A)=d,a,b,)。构造优先关系表方法如下: 对Pab,或PaQb,有ab;对PaR,而bFIRSTVT(R),有ab;对PRb

30、,而aFIRSTVT(R),有ab。由此得到:由S(A)得:();由S(A得:(FIRSTVT(A),即:(d,(a ,(b,(;由AdA得:dFIRSTVT(A),即:dd,da,db,d(;由SA)得,LASTVT(A),即:d),a),b),);由ASd得:LASTVT(S)d,即:ad,bd,)d;此外,由#S#得:#;由#FIRSTVT(S)得:#a,#b,#(;脂由LASTVT(S)#得:d#,a#,b#,)#。最后得到算符优先关系表,见表5-7-2。表5-7-2 算符优先关系表ab()d#ab()d#由表5-7-2可以看出,任何两个终结符之间至少只满足、三种优先关系之一,故GS为

31、算符优先文法。SASASdASd图5-7-3 句型SdSdS的语法树2为求出句型SdSdS的短语、简单短语、句柄,我们先画出该句型对应的语法树,如图5-7-3所示。由图5-7-3得到:短语:S,SdS,SdSdS,SdSdS简单短语即直接短语:S句柄即最左直接短语:S素短语:SdS,它同时也是该句型的最左素短语。3输入串adb#的分析过程见表5-7-4表5-7-4 输入串adb#的分析过程符号栈输入串说明#(adb)#移进#adb)#移进#adb)#用Sa归约#Sdb)#移进#Sdb)#移进#Sdb)#用Sb归约#SdS)#用AS归约#SdA)#用ASdA归约#A)#移进#A#用SA归约#S#

32、分析成功第四节 习题一、单项选择题1、假设a为终结符,则Aa为工程a.归约b.移进c.承受d.待约2、假设工程集Ik含有A,则在状态k时,仅当面临的输入符号aFOLLOW(A)时,才采取“A动作的一定是。a.LALR文法b.LR0文法c.LR1文法d.SLR1文法3、就文法的描述能力来说,有。a. SLR1LR0 b. LR1LR0c. SLR1LR1d.无二义文法LR14、在LR0的ACTION子表中,如果*一行中存在标记“rj的栏,则。a.该行必定填满r.该行未填满rjc.其他行也有rjd.goto子表中也有rj5、一个 指明了在分析过程中的*时刻所能看到产生式多大一局部。a.活前缀b.前

33、缀c.工程d.工程集解答: 1、A称为归约工程,对文法开场符S的归约工程,如S称为承受工程,Aaa为终结符称为移进工程。在此选b.2、当用产生式A归约时,LR0无论面临什么输入符号都进展归约;SLR1则仅当面临的输入符号aFOLLOW(A)时进展归约;LR1则当在把归约为A的规*句型的前缀Aa前提下,当后跟终结符a时,才进展归约;因此选d。3、由于LR0SLR1 LR1无二义文法,应选c。4、选a。5、选c。二、多项选择题1、一个LR分析器包括。a.一个总控程序b.一个工程集c.一个活前缀d.一*分析表e.一个分析栈2、LR分析器核心局部是一*分析表,该表包括 等子表。a.LL(1)分析b.优

34、先关系c.GOTO d.LRe.ACTION3、每一项ACTIONS,a所规定的动作包括。a.移进b.比拟c.承受d.归约e.报错4、对LR分析表的构造,有可能存在动作冲突。a.移进b.归约c.移进/归约d.移进/移进e.归约/归约5、就文法的描述能力来说,有。a. SLR1LR1b. LR1SLR1c. LR0LR1d. LR1无二义文法 e. SLR1无二义文法6、对LR分析器来说,存在等分析表的构造方法。a.LALRb.LR0c.SLR1d.SLR0e.LR17、自上而下的语法分析方法有 。a.算符优先分析法b.LL1分析法c.SLR1分析法d.LR0分析法e.LALR1分析法解答: 1

35、、一个LR分析器包括一个总控程序和一*分析表,选a、d。2、选c、e。3、选a、c、d、e。4、在LR分析表的构造中有可能存在“移进/“归约和“归约/“归约冲突;应选c、e。5、选a、b、c、d、e。6、选a、b、c、e。7、选a、c、d、e。三、填空题1、对于一个文法,如果能够构造。使得它的均是唯一确定的,则称该文法为LR文法。2、字的前缀是指该字的。3、活前缀是指的一个前缀,这种前缀不含之后的任何符号。4、在LR分析过程中,只要的已扫描局部保持可归约成一个,则扫描过的局部正确。5、将识别的NFA确定化,使其成为以为状态的DFA,这个DFA就是建立的根底。6、A称为工程;对文法开场符S为工程

36、;假设a为终结符,则称Aa为工程;假设B为非终结符,则称Aa为工程。 7、LR0分析法的名字中“L表示,“R表示,“0表示。解答: 1、一*分析表 每个入口2、任意首部3、规*句型 句柄4、输入串 活前缀5、活前缀 工程集合 LR分析算法6、归约 承受 移进 待约7、自左至右分析 采用最右推导的逆过程即最左归约 向右查看0个字符四、综合题1、对于文法GS: SAS|b ASA|a1列出所有LR0工程2列出构成文法LR0工程集规*族。解答:首先将文法G拓广为GS:SSSAS|bASA|a1文法GS的LR0工程是: 1、SS5、SAS9、ASA 2、SS6、Sb10、ASA 3、SAS7、Sb11

37、、Aa 4、SAS8、ASA12、Aa2、列出构成文法LR0工程集规*族。用-CLOSURE闭包方法构造文法G的LR0工程集规*族如下:I0:1、SS I3:9、ASAI6:12、Aa 3、SAS8、ASAI7:7、Sb 8、ASA3、SAS 11、Aa6、Sb 6、Sb11、AaI1:2、SSI4:10、ASA 9、ASA4、SAS8、ASA3、SAS11、Aa6、Sb3、SAS8、ASA6、Sb 11、AaI2:4、SASI5:5、SAS 3、SAS9、ASA6、Sb8、ASA 8、ASA11、Aa 11、Aa3、SAS6、Sb注意:I1中的SS和ASA是由状态I0中的1和3读入一个S字符

38、后得到的下一个工程;,而I4中的ASA和AAS则是由I3中的9和3读入一个A字符后得到的下一个工程;I5中的SAS和ASA则是由I4中的4和8读入一个S字符后得到的下一个工程。状态全体构成了文法G的LR0规*族。第八节 习题一、单项选择题1、中间代码生成所依据的是。a.语法规则b.词法规则c.语义规则d.等价变换规则2、四元式之间的联系是通过实现的。a.指示器b.临时变量c.符号表d.程序变量3、后缀式ab+cd+/可用表达式来表示。a.a+b/c+db.(a+b)/(c+d)c.a+b/(c+d)d.a+b+c/d4、表达式ABCD的逆波兰表示为。a.ABCDb. ABCDc. ABCDd.

39、 ABCD5、中间代码的树型表示+ABCD+ 所对应的表达式为。 a.A+B+C+Db.A+(B+C)+Dc.(A+B)+C+Dd.(A+B)+(C+D)6、四元式表示法的优点为。a.不便于优化处理,但便于表的更动b.不便于优化处理,但节省存储空间c.便于优化处理,也便于表的更动d.便于表的更动,也节省存储空间7、终结符具有属性。a.传递b.继承c.抽象d.综合解答 1、选c。2、四元式之间的联系是通过临时变量实现的,应选b。3、选b。4、选b。5、选d。6、四元式表示法的优点与间接三元式一样,应选c。7、选d。 二、多顶选择题1、中间代码主要有。a四元式b二元式c三元式d后缀式e间接三元式2

40、、下面中间代码形式中,能正确表示算术表达式a+b+c的有。+a +b c+ ca baab+c+babc+c d ea+b+c3、在下面的语法制导翻译中,采用拉链-回填技术。a赋值语句bgoto语句 c条件语句d循环语句4、以下中间代码形式有益于优化处理。a三元式b四元式c间接三元式d逆波兰表示法e树形表示法5、在编译程序中安排中间代码生成的目的是。a便于进展存储空间的组织b利于目标代码的优化c利于编译程序的移植d利于目标代码的移植e利于提高目标代码的质量+a *a b*+ ca b6、下面的中间代码形式中,能正确表示算术表达式a+b*c。题aab+c*babc*+ca+b*cd e7、三地址

41、代码语句具体实现通常有表示方法。a逆波兰表示b三元式c间接三元式d树形表示e四元式解答1、选a、c、d、e。2、b、d的中间代码不能正确表示a+b+c,而e 不是中间代码:应选a、c。3、凡涉及到跳转的语句都需要采用拉链回填技术,应选 b、c、d。4、选b、c。5、选b、d。6、选b、e。7、选b、c、e。三、填空题1、中间代码有等形式,生成中间代码主要是为了使。2、语法制导翻译既可以用来产生代码,也可以用来产生指令,甚至可用来对输入串进展。3、当源程序中的标号出现“先引用后定义时,中间代码的转移地址须持时才能确定,因而要进展。4、文法符号的属性有两种,一种称为,另一种称为。5、后缀式abc-

42、/所代表的表达式是,表达式(a-b)*c可用后缀式表示。6、用一*辅以的方法来表示中间代码,这种表示法称为间接三元式。解答1、逆波兰记号、树形表示、三元式、四元式目标代码的优化容易实现2、中间目标解释执行3、标号定义回填4、继承属性综合属性5、a/(b-c)ab-c*6、间接码表三元式表四、综合题1、给出以下表达式的逆波兰表示后缀式: a*(-b+c) (AB)(CDE)2、写出算术表达式:A+B*(C-D)+E/(C-D)N的四元式序列;三元式序列;间接三元式序列解答1、abc+*; ABCDE2、表达式的四元式序列:表达式的三元式序列 间接三元式序列1(-,C,D,T1)1(-,C,D)

43、1(-,C,D)2(*,B,T1,T2)2(*,B,(1) 2(*,B,(1)3(+,A,T2,T3)3(+,A,(2) 3(+,A,(2)4(-,C,D,T4)4(-,C,D) (,(1),N) 5(,T4,N,T5)5(,(4),N) (/,E,(4) (/,E,T5,T6) (/,E,(5) (+,(3),(5) (+,T3,T6,T7) (+,(3),(6) 第三节 习题一、单项选择题1、编译程序使用区别标识符的作用域。a. 说明标识符的过程或函数名 b. 说明标识符的过程或函数的静态层次c. 说明标识符的过程或函数的动态层次 d. 标识符的行号2、在目标代码生成阶段,符号表用于。a.

44、 目标代码生成b. 语义检查c. 语法检查d. 地址分配3、过程信息表不包含。a. 过程入口地址 b. 过程的静态层次 c. 过程名 d. 过程参数信息4、以下关于标识符和名字表达中,正确的选项是。a. 标识符有一定的含义b. 名字是一个没有意义的字符序列c. 名字有确切的属性d.ac都不正确解答:1、b 2、d 3、b 4、c二、多项选择题1、符号表的每一项均包含。a. 名字栏b. 类型栏c. 信息栏d. 值栏e.ad均包含2、对编译程序所用到的符号表,涉及的操作有。a. 填写或更新信息栏内容b. 填入新名c.给定名字,访问它的有关信息d. 杂凑技术e.线性表和排序二叉树3、源程序中的错误一

45、般有。a. 词法错误b. 语法错误c. 语义错误d. 编译错误e. 违反环境限制的错误解答:1、a 、c 2、a、b、c 3、a、b、c、e三、填空题1、符号表中名字栏内容有两种填写方式,它们是填写和填写。2、词法分析阶段的错误主要是,可通过的方法纠正错误。3、符号表中名字的有关信息在和过程中陆续填入。4、在目标代码生成阶段,符号表是的依据。解答:1、标识符 标识符地址及长度2、拼写错误 最小距离匹配 3、词法分析 语法语义分析 4、地址分配四、问答题:1、在编译过程中为什么要建立符号表?解答:在编译过程中始终要涉及到对一些语法符号的处理,这就需要用到语法符号的相关属性。为了在需要时能找到这些

46、语法成分及其相关属性,就必须使用一些表格来保存这些语法成分及其属性,这些表格就是符号表。第四节 习题一、单项选择题1、程序所需的数据空间在程序运行前可确定,称为管理技术。a. 动态存储b. 栈式存储c. 静态存储d. 堆式存储2、堆式动态分配申请和释放存储空间遵守原则。a. 先请先放b. 先请后放c. 后请先放d. 任意3、静态分配允许程序出现。a. 递归过程 b. 可变体积的数据工程c. 静态变量 d. 待定性质的名字4、在编译方法中,动态存储分配的含义是。a. 在运行阶段对源程序中的数组、变量、参数等进展分配b. 在编译阶段对源程序中的数组、变量、参数进展分配c. 在编译阶段对源程序中的数

47、组、变量、参数等进展分配,在运行时这些数组、变量、参数的地址可根据需要改变d. 以上都不正确5、在编译时有传名功能的高级程序语言是。a.Fortranb. Basicc. Pascald. ALGOL6、栈式动态分配与管理在过程返回时应做的工作有。a. 保护SPb. 恢复SPc.保护TOPd. 恢复TOP解答1、c 2、d 3、c 4、a 5、d 6、b二、多项选择题1、下面需要在运行阶段分配存储空间。a. 数组b. 指针变量c.动态数组d. 静态变量e. 动态变量2、栈式动态分配允许。a. 递归过程b. 分程序构造c. 动态变量d. 动态数组e. 静态数组3、动态存储分配可采用的分配方案有。a. 队式存储分配b.栈式存储分配 c.链式存储分配d. 堆式存储分配 e.线性存储分配4、栈式动态分配与管理因调用

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论