编译原理 作业标准答案
- 格式:docx
- 大小:462.46 KB
- 文档页数:11
编译原理作业标准答案第一章引言一、解释下列各词源语言:编写源程序的语言(基本符号,关键字),各种程序设计语言都可以作为源语言。
源程序: 用接近自然语言(数学语言)的源语言(基本符号,关键字)编写的程序,它是翻译程序处理的对象。
目标程序: 目标程序是源程序经过翻译程序加工最后得到的程序。
目标程序(结果程序)一般可由计算机直接执行。
低级语言:机器语言和汇编语言。
高级语言:是人们根据描述实际问题的需要而设计的一个记号系统。
如同自然语言(接近数学语言和工程语言)一样,语言的基本单位是语句,由符号组和一组用来组织它们成为有确定意义的组合规则。
翻译程序: 能够把某一种语言程序(源语言程序)改变成另一种语言程序(目标语言程序),后者与前者在逻辑上是等价的。
其中包括:编译程序,解释程序,汇编程序。
编译程序: 把输入的源程序翻译成等价的目标程序(汇编语言或机器语言),然后再执行目标程序(先编译后执行),执行翻译工作的程序称为编译程序。
解释程序: 以该语言写的源程序作为输入,但不产生目标程序。
按源程序中语句动态顺序逐句的边解释边执行的过程,完成翻译工作的程序称为解释程序。
二、什么叫“遍”?指对源程序或源程序的中间形式(如单词,中间代码)从头到尾扫描一次,并作相应的加工处理,称为一遍。
三、简述编译程序的基本过程的任务。
编译程序的工作是指从输入源程序开始到输出目标程序为止的整个过程,整个过程可以划分5个阶段。
词法分析:输入源程序,进行词法分析,输出单词符号。
语法分析:在词法分析的基础上,根据语言的语法规则把单词符号串分解成各类语法单位,并判断输入串是否构成语法正确的“程序”。
中间代码生成:按照语义规则把语法分析器归约(或推导)出的语法单位翻译成一定形式的中间代码。
优化:对中间代码进行优化处理。
目标代码生成:把中间代码翻译成目标语言程序。
四、编译程序与解释程序的区别?编译程序生成目标程序后,再执行目标程序;然而解释程序不生成目标程序,边解释边执行。
练习5.1解答:输入(4*7+1)*2n,带注释的分析树如下:练习5.2解答: (1)根据表5.3中的语法制导定义建立表达式((a)+(b))的分析树和语法树(2)根据图5.17的翻译模式构造((a)+(b))的分析树和语法树练习5.3解答:设置下面的函数和属性:expr1||expr2:把表达式expr2拼写在表达式expr1后面。
deletep(expr):去掉表达式expr左端的‘(’和右端的‘)’。
E.expr,T.expr,F.expr:属性变量,分别表示E,T,F的表达式。
E.add,T.add,F.add,属性变量,若为true,则表示其表达式中外层有‘+’号,否则无‘+’号。
E.pmark,T.pmark,F.pmark,属性变量,若为true,表示E,T,F的表达式中左端为‘(’,右端是‘)’。
语法制导定义如下:产生式语义规则E -> E1 +T if(T.pmark==true)THEN E.expr=E1.expr||'+'||deletep(T.expr) ELSE E.expr:=E1.expr||'+'||T.expr;E.add:=true;E.pmark:=false;E -> T if(T.pmark==true)THEN E.expr:=deletep(T.expr)ELSE E.expr:=T.expr;E.add:=T.add;E.pmark:=false;T -> T1*F T.expr:=T1.expr||'*'||F.expr; T.add:=false;T.pmark:=false;T -> F T.expr:=F.expr; T.add:=F.add;T.pmark:=F.pmark;F -> (E) if(E.add==false)THEN BEGINF.expr:=E.expr;F.add:=false;F.pmark:=false;ENDELSE BEGINF.expr:='('||E.expr||')';F.add:=true;F.pmark:=true;END;F -> id F.expr:=id.lexval;F.add:=false;F.pmark:=false;练习5.4解答: (1)语法制导定义如下:产生式语义规则E -> E1+T if(E1.type==int) AND (T.type==int) THEN E.type:=intELSE E.type:=real;E -> T E.type:=T.type;T -> num T.type:=int;T -> num.num T.type:=real;(2)设E.pf和T.pf分别是E和T的前缀形式,||是两个字符串的连接,语法制导定义如下:产生式语义规则E -> E1+T if(E1.type==int) AND (T.type==int)THEN E.type:=intELSE BEGINE.type:=real;if(E1.type==int) AND (T.type==real)THEN E1.pf:='inttoreal'||E1.pfELSE if(E1.type==real)AND(T.type==int)THEN T.pf:='inttoreal'||T.pfEND;E.pf:='+'||E1.pf||T.pf;E -> T E.type:=T.type; E.pf:=T.pf;T -> num T.type:=int; T.pf:=int.lexval;T ->num.numT.type:=real; T.pf:=real.lexval;练习5.5解答: (1)用综合属性决定s.val的语法制导定义:产生式语义规则S -> L S.val:=L.val;S ->L1.L2S.val:=L1.val+L2.val*L2.p;L -> B L.val:=B.val; L.p:=2-1;L -> L1B L.val:=L1.val*2+B.val; L.p:=L.p*2-1;B -> 0 B.val:=0;B -> 1 B.val:=1;注:L.p表示恢复L.val的因子。
第二章P-36-6(1)L(G)是0~9组成的数字串;(2)最左推导:N⇒ND⇒NDD⇒NDDD⇒DDDD⇒0DDD⇒01DD⇒012D⇒0127N⇒ND⇒DD⇒3D⇒34N⇒ND⇒NDD⇒DDD⇒5DD⇒56D⇒568最右推导:N⇒ND⇒N7⇒ND7⇒N27⇒ND27⇒N127⇒D127⇒0127N⇒ND⇒N4⇒D4⇒34N⇒ND⇒N8⇒ND8⇒N68⇒D68⇒568P-36-7G(S):(没有考虑正负符号问题)S→P|APP→1|3|5|7|9A→AD|NN→2|4|6|8|PD→0|N或者:(1)S→ABC|CA→1|2|3|4|5|6|7|8|9B→BA|B0|εC→1|3|5|7|9P-36-8G(E):E→T|E+T|E-TT→F|T*F|T/FF→(E)|i最左推导:E⇒E+T⇒T+T⇒F+T⇒i+T⇒i+T*F⇒i+F*F⇒i+i*F⇒i+i*iE⇒T⇒T*F⇒F*F⇒i*F⇒i*(E)⇒i*(E+T)⇒i*(T+T)⇒i*(F+T)⇒i*(i+T)⇒i*(i+F)⇒i*(i+i)最右推导:E⇒E+T⇒E+T*F⇒E+T*i⇒E+F*i⇒E+i*i⇒T+i*i⇒F+i*i⇒i+i*iE⇒T⇒T*F⇒T*(E)⇒T*(E+T)⇒T*(E+F)⇒T*(E+i)⇒T*(T+i)⇒T*(F+i)⇒T*(i+i)⇒F*(i+i)⇒i*(i+i)语法树:SiSeSiSiiSiS i S eS iiP-36-9句子:iiiei 有两个语法树: S ⇒iSeS ⇒iSei ⇒iiSei ⇒iiiei S ⇒iS ⇒iiSeS ⇒iiSei ⇒iiiei因此iiiei 是二义性句子,因此 该文法是二义性的。
P-36-10 S →TS|T T →(S)|()P-36-11L1: G(S): S →AC A →aAb|ab C →cC|ε L2: G(S): S →AB A →aA|ε B →bBc|bc L3: G(S): S →AB A →aAb|ε B →aAb|ε L4: G(S): S →1S0|A A →0A1|ε或者:S →A|B A →0A1|ε B →1B0|A 第三章(1)Ei+i+iE +TE +TT F iF iF iEE +TT F iT *FF iii+i*i Ei-i-iE-TE -TT F iF iF i确定化:最小化:{0,1,2,3,4,5},{6}{0,1,2,3,4,5}0={1,3,5} {0,1,2,3,4,5}1={1,2,4,6} {0,1,2,3,4},{5},{6} {0,1,2,3,4}0={1,3,5} {0,1,2,3},{4},{5},{6}{0,1,2,3}0={1,3} {0,1,2,3}1={1,2,4} {0,1},{2,3},{4},{5},{6}{0,1}0={1} {0,1}1={1,2} {2,3}0={3} {2,3}1={4} {0},{1},{2,3},{4},{5},{6}P64-8(1)(0|1)*01(2)(1|2|3|4|5|6|7|8|9)(0|1|2|3|4|5|6|7|8|9)*(0|5)|(0|5)(3)0*1(0|10*1)* | 1*0(1|01*0)*P84-12(a)a最小化:{0,1} {2,3}{0,1}a={1},{0,1}b={2}{2,3}a={0,3},{2,3}={3}{0,1},{2},{3}a(b)已经确定化,只需最小化:{0,1},{2,3,4,5}{0,1}a = {1} {0,1}b = {2,4}{2,3,4,5}a = {1,3,0,5} {2,3,4,5}b = {2,3,4,5}又:{2,4}a = {1,0} {2,4}b = {3,5} {3,5}a={3,5} {3,5}b = {2,4} 分划为:{0,1},{2,4},{3,5}{0,1}a = {1} {0,1}b = {2,4}{2,4}a = {1,0} {2,4}b = {3,5}{3,5}a = {3,5} {3,5}b = {2,4}所以不能再分aP64-14正规式:(0|10)*还可以:然后再确定化,最小化,结果应该一样。
编译原理习题答案1、正规文法又称DA、0型文法B、1型文法C、2型文法D、3型文法2、对于无二义性的文法,规范归约是BA.最左推导B.最右推导的逆过程C.最左归约的逆过程D.最右归约的逆过程。
3、扫描器的任务是从源程序中识别出一个个单词符号4、程序所需的数据空间在程序运行前就可确定,称为A管理技术。
A静态存储B动态存储C栈式存储D堆式存储5、编译过程中,语法分析器的任务是(B)。
①分析单词是怎样构成的②分析单词串是如何构成语句和说明的③分析语句和说明是如何构成程序的④分析程序的结构A、②③B、②③④C、①②③D、①②③④6、文法G:E→E+T|TT→T某P|PP→(E)|i则句型P+T+i的句柄和最左素短语分别为BA.指示器B.临时变量C.符号表D.程序变量8、程序语言的单词符号一般可以分为保留字、标识符、常数、运算符、界符等等。
9、下列B优化方法是针对循环优化进行的。
A.删除多余运算B.删除归纳变量C.合并已知量D.复写传播10、若文法G定义的语言是无限集,则文法必然是AA、递归的B、前后文无关的C、二义性的D、无二义性的11、文法G产生的D的全体是该文法描述的语言。
A、句型B、终结符集C、非终结符集D、句子12、Chomky定义的四种形式语言文法中,0型文法又称为A文法;1型文法又称为C文法。
A.短语文法B.上下文无关文法C.上下文有关文法D.正规文法A.短语文法B.上下文无关文法C.上下文有关文法D.正规文法13、语法分析最常用的两类方法是自顶向下和自底向上分析法。
14、一个确定的有穷自动机DFA是一个AA五元组(K,∑,f,S,Z)B四元组(VN,VT,P,S)C四元组(K,∑,f,S)D三元组(VN,VT,P)A、语法B、语义C、代码D、运行15、B不属于乔姆斯基观点分类的文法。
A、上下文无关文法B、算符优先文法C、上下文有关文法D、正规文法16、一个文法所描述的语言是A;描述一个语言的文法是BA.唯一的B.不唯一的C.可能唯一,可能不唯一A.唯一的B.不唯一的C.可能唯一,可能不唯一17、语法分析是依据语言的语法规则进行的,中间代码产生是依据语言的等价变换规则进行的。
《编译原理》作业参考答案一、填空1.图二图一。
2.文法是无ε产生式,且任意两个终结符之间至多有一种优先关系的算符文法。
3.最右推导最右推导。
4.对于循环中的有些代码,如果它产生的结果在循环中是不变的,就把它提到循环外来。
把程序中执行时间较长的运算替换为执行时间较短的运算。
5.对于文法中的每个非终结符A的各个产生式的候选首符集两两不相交;对文法中的每个非终结符A,若它存在某个候选首符集包含ε,则FIRST(A)∩FOLLOW(A)= ø6.控制。
7.语义分析和中间代码产生8.自上而下自下而上自上而下9.自下而上表达式10.自下而上11.源程序单词符号12. DFA初态唯一,NFA初态不唯一;DFA弧标记为Σ上的元素,NFA弧标记为Σ*上的元素;DFA的函数为单射,NFA函数不是单射13.词法,词法分析器,子程序,语法14.ε,a,ab,ab15.终结符号,非终结符号,产生式16.L(G)={a n | n≥1}17.1型,2型,3型18.二义的19.快20.终态,输入字21.单词符号,终结符22.归约23.必须24.直接25.终结符,更快26.E→E+∙T, E→E∙+T, E→∙E+T, E→E+T∙27.归约—归约28.类型检查,一致性检查29.词法分析、词法30.语法分析程序、语法31。
终结符号、产生式、开始符号、非终结符32.2、2、333.不需要避开34.符合、不符合35.推导36.包括37.Ass38.一定没有、一定没有、至多只有一个39.SLR(1)40.移进——归约41.a.控制流检查、b.一致性检查、c.相关名字检查二、判断下面语法是否正确1 ×2 ×3 √4 ×5 √6 ×三、简答题1.词法分析的任务是对输入的源程序进行单词及其属性的识别,为下一步的语法分析进行铺垫;有两种方法可以实现词法分析器:一,手工编写词法分析程序。
二,由词法分析器自动生成程序生成。
编译原理独立作业2010.5一、简答题1、 构造一个文法使其生成的语言是不允许0打头的偶正整数集合。
2、文法][E G :T T E T E E -+→,F F T F T T /*→,i E F )(→,构造句型i T T T *+-的语法树,并指出该句型的短语、直接短语、句柄、素短语和最左素短语。
3、 某LL(1)文法的预测分析表如下,请在下述分析过程表中填入输入串( a , a )$ 的分析过程。
4、 文法][S G :R L S =→,R S →,R L *→,i L →,L R →,求增广文法中LR(1)项目集的初态项目集I 0。
5、文法][S G :G G S S ;→,()G G t H →,)(S a H →,求出各非终结符的FISTVT 和LASTVT 集合。
二、分析题:1、构造自动机,使得它能识别字母表{0,1}上以00结尾的符号串,将构造的自动机确定化,并写出相应的正规文法。
2、文法][S G :RT eT S → εDR T → εdR R → bd a D →,写出每个非终结符的FIRST 集和FOLLOW 集,并判断该文法是否为LL(1)文法。
3、若有文法][S G :AB S → εaBa A → εb A b B → (1)试证明该文法是SLR(1) 文法,并构造SLR(1)分析表。
(2)给出输入串aa # 的分析过程。
参考答案一、简答题1、构造一个文法使其生成的语言是不允许0打头的偶正整数集合。
8|6|4|2|ABC Z → 9|8|7|6|5|4|3|2|1→A ε|0|B AB B → |8|6|4|2|0→C2、文法][E G :T T E T E E -+→,F F T F T T /*→,i E F )(→,构造句型i T T T *+-的语法树,并指出该句型的短语、直接短语、句柄、素短语和最左素短语。
短语:T ,T-T ,i ,T*i ,T-T+T*i直接短语:T , i 句柄: T素短语(P72):T-T,i 最左素短语:T-T3 某LL(1)文法的预测分析表如下,请在下述分析过程表中填入输入串( a , a )$ 的分析过程。
程序设计语言与编译——语言的设计与实现(第2版)习题4答案4-5 解:上下文有关文法(1型文法),产生的语言L(G){=a i b i c i | i≥1,i为整数} 4-6 解:3型文法,L(G)={a i | i≥1,i为奇数}4-7 解:2型文法,L(G)={a i b i | i≥1,i为整数}4-8 解:1型文法,L(G)={a i b i c i | i≥1,i为整数}4-9 解:1. 最左推导最右推导S⇒ (A) ⇒ (B) ⇒(SdB) S⇒ (A) ⇒ (B) ⇒ (SdB)⇒ ((A)dB) ⇒ ((B)dB) ⇒ (SdS) ⇒ (Sda)⇒ ((S)dB) ⇒ ((b)dB) ⇒ ((A)da ⇒ ((B)da)⇒ ((b)dS) ⇒ ((b)da) ⇒ ((s)da⇒ ((b)da)2. 语法树4-10解:1. 因为存在推导S ⇒ SbF ⇒ SbP ⇒ Sbc ⇒ Fbc ⇒ FaPbc所以FaPbc是文法G (S) 的一个句型。
2. 语法树4-11解:因为串aaabaa可有下列两棵不同的语法树所以文法G (S)是二义文法。
因为串i(*可有下列两棵不同的语法树9-2解:(1)消除文法G的②产生式直接左递归。
A→SeA' | fA' ③A'→dA' | ε④(2)消除间接左递归:按S.A排序,将S的①产生式代入③有A→AaeA' | AbeA' | ceA' | fA' ⑤(3)消除⑤的直接左递归有A→ceA'A" | fA'A" ⑥A"→aeA'A" | beA'A" | ε⑦(4)对S的①产生式提公因子有S→AB | c ⑧B→| a | b ⑨(5)最后,文法G提取公因子,消除左递归后的产生式由⑧, ⑨, ⑥, ⑦和④组成,无多余的产生式。
编译原理试题及答案
试题:
1. 解释编译原理的定义,同时给出编译器的作用。
2. 简要描述编译过程中的四个基本步骤。
3. 解释词法分析器的功能和作用。
4. 解释语法分析器的功能和作用。
答案:
1. 编译原理是研究如何将高级语言程序转化为等价机器语言程序的一门学科。
编译器是将高级语言文本转换成等价的机器语言的软件工具。
它负责将源代码转化为目标代码,以便计算机能够理解和执行。
2. (1) 词法分析:将源代码分解成一系列单词或标记。
(2) 语法分析:根据语法规则组织单词或标记形成语法树。
(3) 语义分析:分析语法树以检测语义错误。
(4) 代码生成:根据语法树生成目标代码。
3. 词法分析器的功能是将源代码分解成一系列单词或标记。
它将源代码读取为字符流,然后将这些字符组成单词,同时可以去除空格、注释等不具有实际意义的内容。
词法分析器的作用是为语法分析器提供正确的单词序列,为后续的语义分析和代
码生成步骤建立基础。
4. 语法分析器的功能是根据语法规则组织单词或标记形成语法树。
它通过构建语法树来分析源代码的语法结构,同时可以检测语法错误。
语法分析器的作用是为后续的语义分析和代码生成步骤提供一个结构化的表示形式,便于后续的处理和转换。
1第2章 习题2-1 设有字母表A 1 ={a,b,c,…,z},A 2={0,1,={0,1,……,9},9},试回答下列问题:,试回答下列问题:,试回答下列问题:(1) 字母表A 1上长度为2的符号串有多少个?的符号串有多少个? (2) 集合A 1A 2含有多少个元素?含有多少个元素?(3) 列出集合A 1(A 1∪A 2)*中的全部长度不大于3的符号串。
的符号串。
2-2 试分别构造产生下列语言的文法:试分别构造产生下列语言的文法:试分别构造产生下列语言的文法: (1){a nb n|n≥0};|n≥0}; (2){a n b m c p |n,m,p≥0};|n,m,p≥0};(3){a n#b n|n≥0}∪|n≥0}∪{c {c n#d n|n≥0};|n≥0};(4){w#w r # | w ∈{0,1}*,w r 是w 的逆序排列的逆序排列 } }; (5)任何不是以0打头的所有奇整数所组成的集合;的集合;(6)所有由偶数个0和偶数个1所组成的符号串的集合。
号串的集合。
2-3 试描述由下列文法所产生的语言的特点:试描述由下列文法所产生的语言的特点: (1)S→10S0)S→10S0 S→aA S→aA A→bA A→bA A→a A→a (2)S→SS S→1A0S→1A0 A→1A0A→1A0A→ε (3)S→1A )S→1A S→B0S→B0 A→1A A→1A A→C A→C B→B0B→B0 B→C B→C C→1C0C→1C0C→ε(4)S→aSS )S→aSS S→a S→a 2-4 试证明文法试证明文法试证明文法 S →AB|DC A →aA|a B →bBc|bc C →cC|c D →aDb|ab为二义性文法。
为二义性文法。
2-5 对于下列的文法对于下列的文法对于下列的文法 S →AB|c A →bA|a B →aSb|c试给出句子bbaacb 的最右推导,并指出各步直接推导所得句型的句柄;指出句子的全部短语。
编译原理作业参考答案作业一一、是非题1.(×)2.(×)3.(×)4.(×)5.(×)6.(√)7. (√)8.(√)9.(√) 10.(×) 11.(√) 12.(√) 13.(√)二、填空题1.(词法分析),(语法分析),(中间代码生成),(代码优化),(目标代码生成)2.(单词符号),(语法单位)。
3.(源程序),(单词符号)4.(语法),(语义)5. (词法分析)、(语法分析)、(语义分析),(中间代码产生),(代码优化),(目标代码生成)6.(解释方式)7. (语法规则)8. (上下文无关文法)9. (自上而下分析法),(自下而上分析法)10. (规范推导)11. (最左归约)三、名词解释题:1.词法分析器-----执行词法分析的程序。
2. 自编译方式------先对语言的核心部分构造一个小小的编译程序,再以它为工具构造一个能够编译更多语言成分的较大编译程序。
如此扩展下去,就像滚雪球一样,越滚越大,最后形成人们所期待的整个编译程序。
3. 遍-----所谓“遍”就是对源程序或中间结果长头到尾扫描一次,并作有关的加工处理,生成新的中间结果或目标程序。
4. 编译程序-----一种翻译程序: 能够把某一种语言程序(称为源语言程序)转换成另一种语言(成为目标程序),而后着与前者在逻辑上是等价的。
5. 超前搜索-----所谓超前搜索是在词法分析过程中,有时为了确定词性,需超前扫描若干个字符。
6. 短语------令G是一个文法,S划文法的开始符号,假定αβδ是文法G的一个句型,如果有SαAδ且Aβ,则称β是句型αβδ相对非终结符A的短语。
7. 规范句型------由规范推导所得到的句型。
8. 句柄------一个句型的最左直接短语。
9. -规范推导-----最右推导又称为规范推导。
四、简答题:1. 正规式a ( a | b )*。
2.(a*b|b*a)={a,b,ab,ba,aab,bba……}3.状态转换图是一张有限方向图。
平时作业1对于下列语言分别写出它们的正规表达式。
2 (1)英文字母组成的所有符号串,要求符号串中顺序包含五个元音答:令Letter 表示除这五个元音外的其它字母。
((letter) *A(letter) *E(letter) *l(letter) *O(letter) *U(letter)) *⑵英文字母组成的所有符号串,要求符号串中的字母依照词典顺序排列答: * * *A ⑶工={0,1}上的含偶数个1的所有串。
答:(0|10 *1)*⑷工={0,1}上的含奇数个1的所有串。
答:(0|10 *1)*1⑸具有偶数个0和奇数个1的有0和1组成的符号串的全体。
答:设S 是符合要求的串,|S|=2k+1 (k >0)。
则 STS 1OIS 2I, |S i |=2k (k>0 ), |S 2|=2k (k > 0)。
且S 是{0,1}上的串,含有奇数个0和奇数个1。
S 2是{0,1}上的串,含有偶数个0和偶数个1。
考虑有一个自动机 M 接受S ,那么自动机 M 如下:和L(M 1)等价的正规表达式,即S 1为:((0 11)|(01|10)(00|11)*(01|10)) *(01|10)(00|11)类似的考虑有一个自动机 M 接受S2,那么自动机 M 如下:011110oa[ii和L(M 2)等价的正规表达式,即S 2为:((00|11)|(01|10)(00|11)*(01|10)) *00|11因此,S为:((00|11)|(01|10)(00|11) *(01|10)) *(01|10)(00|11) *0|((00|11)|(01|10)(00|11)*(01|10)) *1(6) 不包含子串011的由0和1组成的符号串的全体。
* * *答:1 |1 0(叩0) (1| £)⑺ 由0和1组成的符号串,把它看成二进制数,能被3整除的符号串的全体 答:假设w 的自动机如下:对应的正规表达式:(1(01 *0)1|0)3给出接受下列在字母表{0,1}上的语言的DFA 4 (1) 所有以00结束的符号串的集合。
第二章高级语言的语法描述6、令文法G 6为:N →D|ND D → 0|1|2|3|4|5|6|7|8|9(1)G 6 的语言L (G 6)是什么?(2)给出句子01270127、、34和568的最左推导和最右推导。
解答:思路:由N N →→ D|ND 可得出如下推导N =>=>ND ND ND=>=>=>NDD NDD NDD=>…=>=>…=>=>…=>D D n(n >=1=1))可以看出,N 最终可以推导出1个或多个(也可以是无穷)D ,而D D →→ 0|1|2|3|4|5|6|7|8|9可知,每个D 为0~9中的任一个数字,所以,中的任一个数字,所以,N N N 最终推导出的就是由最终推导出的就是由0~9这10个数字组成的字符串。
(1)G 6 的语言L (G 6)是由0~9这10个数字组成的字符串个数字组成的字符串,,或{0{0,,1,1,……,9}+。
(2)(2)句子句子01270127、、34和568的最左推导分别为的最左推导分别为: : N =>=>ND ND ND=>=>=>NDD NDD NDD=>=>=>NDDD NDDD NDDD=>=>=>DDDD DDDD DDDD=>=>=>0DDD 0DDD 0DDD=>=>=>01DD 01DD 01DD=>=>=>012D 012D 012D=>=>=>0127 0127 N =>=>ND ND ND=>=>=>DD DD DD=>=>=>3D 3D 3D=>=>=>34 34N =>=>ND ND ND=>=>=>NDD NDD NDD=>=>=>DDD DDD DDD=>=>=>5DD 5DD 5DD=>=>=>56D 56D 56D=>=>=>568 568 句子01270127、、34和568的最右推导分别为的最右推导分别为: :N =>=>ND ND ND=>=>=>N7N7N7=>=>=>ND7ND7ND7=>=>=>N27N27N27=>=>=>ND27ND27ND27=>=>=>N127N127N127=>=>=>D127D127D127=>=>=>0127 0127 N =>=>ND ND ND=>=>=>N4N4N4=>=>=>D4D4D4=>=>=>34 34N =>=>ND ND ND=>=>=>N8N8N8=>=>=>ND8ND8ND8=>=>=>N68N68N68=>=>=>D68D68D68=>=>=>568 5687、写一个文法,使其语言是奇数集,且每个基数不以0开头。
一、填空题:1-01.编译程序地工作过程一般可以划分为词法分析,语法分析,语义分析,之间代码生成,代码优化等几个基本阶段,同时还会伴有表格处理和出错处理.1-02.若源程序是用高级语言编写地,目标程序是机器语言程序或汇编程序,则其翻译程序称为编译程序•1-03.编译方式与解释方式地根本区别在于是否生成目标代码.1-04.翻译程序是这样一种程序,它能够将用甲语言书写地程序转换成与其等价地用乙语言书写地程序.1-05.对编译程序而言,输入数据是源程序,输出结果是目标程序.1-06.如果编译程序生成地目标程序是机器代码程序,则源程序地执行分为两大阶段:编译阶段和运行阶段如果编译程序生成地目标程序是汇编语言程序,则源程序地执行分为三个阶段:编译阶段,汇编阶段和运行阶段.b5E2RGbCAP1-07.若源程序是用高级语言编写地,目标程序是机器语言程序或汇编程序,则其翻译程序称为编译程序.1-08. 一个典型地编译程序中,不仅包括词法分析、语法分析、中间代码生成、代码优化、目标代码生成等五个部分,还应包括表格处理和出错处理.其中,词法分析器用于识别单词.p1EanqFDPw1-09.编译方式与解释方式地根本区别为是否生成目标代码.2-01.所谓最右推导是指:任何一步a = B都是对a中最右非终结符进行替换地.2-02. 一个上下文无关文法所含四个组成部分是一组__________ 生式.DXDiTa9E3d2-03.产生式是用于定义语法成分地一种书写规则.2-04.设G[S]是给定文法,则由文法G所定义地语言 L(G)可描述为:L(G) = {x | S. x,x € V T*} . RTCrpUDGiT2-05.设G是一个给定地文法,S是文法地开始符号,如果S. x (其中x € V*),则称x是文法地一个处型.5PCzVD7HxA2-06.设G是一个给定地文法,S是文法地开始符号,如果S上x(其中x € V T*),则称x是文法地一个句_ 子.jLBHrnAlLg3-01.扫描器地任务是从源程序中识别出一个个单词符号.4-01.语法分析最常用地两类方法是自上而下和自下而上分析法.4- _________________________________________________________02.语法分析地任务是识别给定地终极符串是否为给定文法地句子_____________________________________________ .4-03.递归下降法不允许任一非终极符是直接左递归地.4-04.自顶向下地语法分析方法地关键是如何选择候选式地问题.4-05.递归下降分析法是自顶向上分析方法.4-06.自顶向下地语法分析方法地基本思想是:从文法地开始符号开始,根据给定地输入串并按照文法地产生式一步一步地向下进行直接推导,试图推导出文法地句子,使之与给定地输入串匹酉己.XHAQX74J0X5-01.自底向上地语法分析方法地基本思想是:从给定地终极符串开始,根据文法地规则一步一步地向上进行直接归约,试图归约到文法地开始符号.LDAYtRyKfE5-02.自底向上地语法分析方法地基本思想是:从输入串入手,利用文法地产生式一步一步地向上进行直接归约,力求归约到文法地开始符号 .Zzz6ZB2Ltk5-03.简单优先方法每次归约当前句型地句柄,算符优先方法每次归约当前句型地最左素短语,二者都是不断移进输入符号,直到符号栈顶出现可归约串地尾,再向前找到可归约串地头,然后归约.dvzfvkwMI15-04.在LR( 0)分析法地名称中,L地含义是自左向右地扫描输入串,R 地含义是最左归约,0地含义是向貌似句柄地符号串后查看0个输入符号•rqyn14ZNXI5-05.在SLR (1)分析法地名称中,S地含义是简单地•6-01.所谓属性文法是一个属性文法是一个三元组:A=(G, V, F), —个上下文无关文法G; —个属性地有穷集V和关于属性地断言或谓词地有穷集 F.每个断言与文法地某产生式相联.EmxvxOtOco6-02.综合属性是用于“自下而上”传递信息.6-03.继承属性是用于“自上而下”传递信息.6-04.终结符只有综合属性,它们由词法分析器提供.7-01.在使用高级语言编程时,首先可通过编译程序发现源程序地全部_A_错误和B 部分错误.SixE2yXPq5a.语法b.语义c.语用d.运行8-01.符号表中地信息栏中登记了每个名字地属性和特征等有关信息,如类型、种属、所占单元大小、地址等等.6ewMyirQFL8-02. 一个过程相应地 DISPLAY表地内容为现行活动记录地址和所有外层最新活动记录地地址.9-01. 一个过程相应地 DISPLAY表地内容为现行活动记录地址和所有外层最新活动记录地地址.9-02.常用地两种动态存贮分配办法是栈式动态分配和堆式动态分配.9-03.常用地参数传递方式有传地址,传值和传名.10-01.局部优化是局限于一个基本块范围内地一种优化.10-02.代码优化地主要目标是如何提高目标程序地运行速度和如何减少目标程序运行时所需地空间.kavU42VRUs、单选题:1-10. 一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括(1应其中,(2)b和代码优化部分不是每个编译程序都必需地词法分析器用于识别(3应语法分析器则可以发现源程序中地.她(1) a.模拟执行器 b.解释器 c.表格处理和出错处理 d. 符号执行器⑵ a.语法分析 b.中间代码生成 C.词法分析 d.目标代码生成⑶ a.字符串 b.语句 c.单词 d.标识符y6v3ALoS89⑷ a.语义错误 b.语法和语义错误 C.错误并校正 d.语法错误1-程序语言地语言处理程序是一种(1)a. (2)b 是两类程序语言处理程序,他们地主要区别在于11.(3)d. M2ub6vSTnP(1) a.系统软件 b.应用软件 c.实时系统 d.分布式系统(2) a.咼级语言程序和低级语言程序 b.解释程序和编译程序c.编译程序和操作系统d.系统程序和应用程序(3) a.单用户与多用户地差别 b.对用户程序地查错能力c.机器执行效率d.是否生成目标代码1-12. 汇编程序是将a翻译成b,编译程序是将c_翻译成d.a.汇编语言程序b.机器语言程序c.高级语言程序1-18.编译程序与具体地机器 a ,与具体地语言a.a. 有关b.无关1-19.使用解释程序时,在程序未执行完地情况下, a 重新执行已执行过地部分a.也能b.不可能1-20.编译过程中,语法分析器地任务就是 (1)分析单词是怎样构成地(3)分析语句和说明是如何构成程序地 b.(2)分析单词串是如何构成语句和说明地(4)分析程序地结构 a. (2)(3)b. (2)(3)(4)c. (1)(2)(3)d.(1)(2)(3)(4) zvpgeqJ1hkd. a 或者be. a 或者cf. b 或者c1-13.下面关于解释程序地描述正确地是b.(1) 解释程序地特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和FORTRA N 语言 (3) 解释程序是为打开编译程序技术地僵局而开发地 a. (1)(2)b. (1)c. (1)(2)(3)d.(2)(3) OYujCfmUCw1-14.高级语言地语言处理程序分为解释程序和编译程序两种 .编译程序有五个阶段,而解释程序通常缺少(1)e 和(1)b.其中,(1)e 地目地是使最后阶段产生地目标代码更为高效.eUts8ZQVRd与编译系统相比,解释系统 (2)d.解释程序处理语言时,大多数采用地是_(3L 方法.⑷a 就是一种典型地 解释型语言.sQsAEJkW5T (1) : a. 中间代码生成 b.目标代码生成 c.词法分析 d.语法分析e.代码优化GMslasNXkA(2) : a. 比较简单,可移植性好,执行速度快b. 比较复杂,可移植性好,执行速度快c. 比较简单,可移植性差,执行速度慢d.比较简单,可移植性好,执行速度慢(3) : a. 源程序命令被逐个直接解释执行b.先将源程序转化为之间代码,再解释执行c.先将源程序解释转化为目标程序 ,在执行d.以上方法都可以(4) : a. BASIC b. C c. FORTRAN d. PASCAL TirRGchYzg1-15.用高级语言编写地程序经编译后产生地程序叫 b .用不同语言编写地程序产生 b 后,可用g 连接在一起生成机器可执行地程序 .在机器中真正执行地是 e. 7EqZcWLZNXa.源程序b.目标程序c.函数d.过程e.机器指令代码 f.模块g.连接程序 h.程序库1-16.要在某一台机器上为某种语言构造一个编译程序 ,必须掌握下述三方面地内容 :c , d , ______f . lzq7IGfO2E a.汇编语言 b. 高级语言 c. 源语言 d. 目标语言e.程序设计方法f.编译方法1-17.由于受到具体机器主存容量地限制 诸阶段地工作往往是(2」进行地. (1) a. 过程b.程序c.批量 ⑵a.顺序b.并行c.成批g.测试方法h.机器语言,编译程序几个不同阶段地工作往往被组合成d.遍 d.穿插(1)d ,1-21.编译程序是一种常用地、软件•a. 应用b.系统1-22.编写一个计算机高级语言地源程序后,到正式上机运行之前,一般要经过b这几步.(1)编辑 (2)编译 (3)连接 (4)运行a. (1)⑵⑶⑷b. (1) (2)(3)c. (1) (3)d.(1) (4)1-23.编译程序必须完成地工作有 a.(1)词法分析⑵语法分析(3)语义分析(4) 代码生成之间代码生成(6) 代码优化a. (1)(2)(3)(4) b. (1) (2)(3)(4)(5) c. (1) (2)(3)(4)(5)(6) NrpoJac3v1d.(1)(2)(3)(4)(6) e. (1)(2)(3)(5)(6)1-24 .“用高级语言书写地源程序都必须通过编译,产生目标代码后才能投入运行”这种说法 a.a.不正确b.正确1-25.把汇编语言程序翻译成机器可执行地目标程序地工作是由b完成地.a.编译器b.汇编器c.解释器d.预处理器1-26.编译程序生成地目标程序b是机器语言地程序.a. 一定b.不一定1-27.编译程序生成地目标程序b是可执行地程序.a. 一定b.不一定1-28 .编译程序是一种 B .A.汇编程序B. 翻译程序C. 解释程序D. 目标程序1nowfTG4KI1-29 .按逻辑上划分, 编译程序第二步工作是 C .A.语义分析B. 词法分析C. 语法分析D. 代码优化fjnFLDa5Zo1-30 •通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括 C . tfnNhnE6e5A.模拟执行器B.解释器C.表格处理和出错处理D.符号执行器2-07 .文法G所描述地语言是 C 地集合.A.文法G地字母表V中所有符号组成地符号串B.文法G地字母表V地闭包V*中地所有符号串C.由文法地开始符号推出地所有终极符串D.由文法地开始符号推出地所有符号串2-08 .乔姆斯基(Chomsky)把文法分为四种类型,即0型、1型、2型、3型.其中3型文法是B . HbmVN777sLA.短语文法B.正则文法C. 上下文有关文法D. 上下文无关文法2-09.文法 G[N]= ({b} , {N , B}, N, {Nb | bB, bN}),该文法所描述地语言是C .A. L(G[N])={b i | i > 0}B. L(G[N])={b 2i | i > 0}C. L(G[N])={b | i > 0}D. L(G[N])={b | i > 1}2-10 .一个句型中地最左B称为该句型地句柄.可选项有:A.短语B.简单短语C.素短语D.终结符号2-11 •设G 是一个给定地文法,S 是文法地开始符号,如果 S .x (其中x € V),则称x 是文法G 地一个B . V7l4jRB8HsA.候选式B. 句型C. 单词D. 产生式2-12 •一个上下文无关文法G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组 D.83ICPA59W9 A.句子 B. 句型 C. 单词 D. 产生式2-13.文法 G[E]:T I E+ T —F I T * F F T a I ( E )该文法句型E+ F* (E + T )地简单短语是下列符号串中地 B .◎ ( E+ T ) ②E+ T ③F ④F* (E + T )可选项有:A )①和③B )②和③C )③和④D )③2-14 .若一个文法是递归地,则它所产生地语言地句子A.是无穷多个B.是有穷多个C.是可枚举地 3-02 •词法分析器用于识别 C .4-08.编译程序中语法分析器接收以 A 为单位地输入.D.个数是常量A.句子B. 句型C.单词D.产生式4-07.在语法分析处理中,FIRST 集合、A.非终极符集B. 终极符集FOLLOW 集合、 SELECT 集合均是 BmZkklkzaaPC. 字母表D.状态集A.单词B. 表达式C.产生式 D. 句子5-06 .在自底向上地语法分析方法中,分析地关键是A.寻找句柄B.寻找句型C.消除递归D.5-07.在LR 分析法中,分析栈中存放地状态是识别规范句型A.句柄B.前缀 C.活前缀选择候选式 AVktR43bpw 地DFA 状态.B. C.D. LR(0)项目 ORjBnOwcEd、是非题(下列各题,你认为正确地,请在题干地括号内打“ 错地打“X” .)1-31 .计算机高级语言翻译成低级语言只有解释一种方式 (X) 2MiJTy0dTT 1-32.在编译中进行语法检查地目地是为了发现程序中所有错误(X) gIiSpiue7A1-34.甲机上地某编译程序在乙机上能直接使用地必要条件是甲机和乙机地操作系统功能完全相同.(X )uEhOU1Yfmh2-15.正则文法其产生式为 A a, A Bb, A,B € V N , a 、b€ V T . 4-09.每个文法都能改写为LL (1)文法.(X )4- 10.递归下降法允许任一非终极符是直接左递归地 5-08.算符优先关系表不一定存在对应地优先函数.(V )(V) IAg9qLsgBX(V) WWGHWVVHPE(X) asfpsfpi4k5-10.LR法是自顶向下语法分析方法(X) ooeyYZTjj15-11.简单优先文法允许任意两个产生式具有相同右部5-12.若一个句型中出现了某产生式地右部,则此右部一定是该句型地句柄 (X)四、名词解释1- 35.扫描遍 _____ 指编译程序对源程序或中间代码程序从头到尾扫描一次2- 16.短语一一设G[Z]是给定文法,w=xuy € V+,为该文法地句型,如果满足下面两个条件:① Z xUy ; ② U 「u;则称句型xuy 中地子串u 是句型xuy 地短语.2-17.简单短语一一设 G[Z]是给定文法,w=xuy € S ,为该文法地句型,如果满足下面两个条件:v4bdyGious① Z — xUy ; ② 4 u ;则称句型xuy 中地子串u 是句型xuy 地简单短语(或直接短语).2-18.句柄——一个句型中地最左简单短语称为该句型地句柄4- 11.语法分析--按文法地产生式识别输入地符号串是否为一个句子地分析过程 4- 12.选择符集合 SELECT--给定上下文无关文法地产生式a , A € V N , a € V *,若a ^ s ,则SELECT(A> a )=FIRST( a ),其中如果 a —、s ,贝U SELECT(A> a )=FIRST( a s ) U FOLLOW(A),FIRST( a s )表示 FIRST( a )地非{ s }兀素.J0bm4qMpJ9Aw a 年3是文法G'中地一个规范推导,G'是G 地拓广文法,符号串丫是a B 地前缀,则称 丫是G 地,也是G'地一个活前缀.其中S'为文法开始符号.或:可归前缀地任意首 部. XVauA9grYP5- 15.可归前缀——是指规范句型地一个前缀,这种前缀不含句柄之后地任何符号 5-16.LR(0)项目一一把产生式右部某位置上标有圆点地产生式称为相应文法地一个 LR(0)项目.5- 17.最左素短语一一设有文法 G[S],其句型地素短语是一个短语,它至少包含一个终结符,并除自身外不包含其它素短语,最左边地素短语称最左素短语.bR9C6TJscw6- 05.语义规则一一对于文法地每个产生式都配备了一组属性地计算规则,称为语义规则 6- 06.翻译方案一一将属性文法中地语义规则用花括号{ }括起来,插在产生式右部地合适地方,指明语义规则地计算次序,陈述一些细节,得到一种语义动作与语法分析交错地表示方法,以表述语义动作在语法 分析过程中地执行时刻,称之为翻译方案 .pN9LBDdtrd7- 03.后缀式 -- 一种把运算量(操作数)写在前面把算符写在后面(后缀)地表示法.即一个表达式E 地后缀形式可以如下定义:(1)如果E 是—个变量或常量,则 E 地后缀式是E 自身.⑵ 如果E 是Eop E 2形式地表达式,这里 op 是任何二元操作符,则 E 地后缀式为&'巨’op,这里 E'和E 2‘分别为E 1和E 2地后缀式.DJ8T7nHuGT(X) BkeGulnkxl 5-13. 一个句型地句柄一定是文法某产生式地右部 7-02.数组元素地地址计算与数组地存储方式有关 •(V)8-03.在程序中标识符地出现仅为使用性地.9-04.对于数据空间地存贮分配, FORTRA 采(V) PgdOOsRIMo(X) 3cdXwckm15(X) h8c52WOngM5-14.活前缀一一若S' a(3)如果E是( EJ形式地表达式,则日地后缀式就是E地后缀式.答:一个过程地活动指地是该过程地一次执行.就是说,每次执行一个过程体,产生该过程体地一个活动9-07.活动记录答:为了管理过程在一次执行中所需要地信息,使用一个连续地存储块,这样一个连续地存储块称为活动记录.9-08.活动地生存期答:指地是从执行某过程体第一步操作到最后一步操作之间地操作序,包括执行过程时调用其它过程花费地时间.10-06. 基本块地DAG.答:一个基本块地 DAG是—种其结点带有下述标记或附加信息地DAG.(1)图地叶结点(没有后继地结点)以一标识符(变量名)或常数作为标记,表示该结点代表该变量或常数地值.如果叶结点用来代表某变量A地地址,则用addr( A)作为该结点地标记.通常把叶结点上作为标记地标识符加上下标0,以表示它是该变量地初值 .QF81D7bvUA(2)图地内部结点(有后继地结点)以一运算符作为标记,表示该结点代表应用该运算符对其后继结点所代表地值进行运算地结果.4B7a9QFw9h(3)图中各个结点上可能附加一个或多个标识符,表示这些变量具有该结点所代表地值五、简答题:2-19什么是句子?什么是语言?答:设G是一个给定地文法,S是文法地开始符号,如果S〔x(其中x € V T*),则称x是文法地一个句子.设G[S]是给定文法,则由文法G所定义地语言L(G)可描述为:L(G) = {x | S . x,x € V T*} . ix6iFA8xoX 2-20.已知文法 G[E]为:T|E+T|E-T—F|T*F|T/FF^( E) |i①该文法地开始符号(识别符号)是什么?②请给出该文法地终结符号集合V T和非终结符号集合M.③找出句型T+T*F+i地所有短语、简单短语和句柄.解:①该文法地开始符号(识别符号)是 E.②该文法地终结符号集合V T={+、-、*、/、(、)、 i}.非终结符号集合M={E、T、F}.③句型 T+T*F+I地短语为i、T*F、第一个 T、T+T*F+i;简单短语为i、T*F、第一个T;句柄为第一个T.2-21.已知文法 G[S]为:S T dABA T aA|aB T Bb| £①G[S]产生地语言是什么?②G[S]能否改写为等价地正规文法?8 /注6带+号地结点为初始状态;解:① G[S]产生地语言是 L(G[S])={da n b m| n> 1,m>0}.②G[S]能改写为等价地正规文法,其改写后地等价地正规文法 G[S / ]为:S J dA A T aA|aB|a BT bB|b2- 22.设有语言L(G)={ada R| a € (a,b) *,a R为a 之逆},试构造产生此语言地上下文无关文法G.wt6qbkCyDE解:根据题义,可知a R为a 之逆地含义就是句子中地符号 a 、b 以d 为中心呈左右对称出现;由于a€ (a,b) *, 所以a 、b 地个数可以为零.所以可构造产生此语言地上下文无关文法 G[S]为:S T aSa|bSb|d Kp5zH46zRk3- 03 .简述DFA 与NFA 有何区别?答:DFA 与NFA 地区别表现为两个方面:一是NFA 可以若干个开始状态,而DFA 仅只一个开始状态.另一方 面,DFA 地映象M 是从KXE 到K,而NFA 地映象M 是从KX 刀到K 地子集,即映象 M 将产生一个状态 集合(可能为空集),而不是单个状态.YI4HdOAA61 3- 04.试给出非确定自动机地定义. 答:一个非确定地有穷自动机(NFA M 是一个五元组:M=( K, X, f, S , Z).其中:1. K 是一个有穷集,它地每个元素称为一个状态;2. 工是一个有穷字母表,它地每个元素称为一个输入符号,所以也称工为输入符号表;3. f 是状态转换函数,是在 KX X * T K 地子集地映射,即,f: K X X *T 2K;表明在某状态下对于某输入符号可能有多个后继状态; ch4PJx4BII4. S ( K 是- -个非空初态集;5. Z ( K 是- -个终态集(可空). 3-05.为正规式(a|b ) *a(a|b)构造一个等价地确定地有限自动机.解答:3- 06.给定下列自动机,将其转换为确定地自动机qd3YfhxCzo注:带+号地结点为初始状态;带一号地结点为终止状态+AE dVG dd BC+ startSd* D(1) 把此自动机转换为确定自动机 DFA.⑵给出此DFA 地正则表达式. 解答:(1):有状态矩阵如图:501nNvZFisa bab=00,1 2二 0 01 21 2 —01 01 2-2 1 2-2 1 29 / 1 6 2+— d •+— d • S A ABCE G+[SA][A][A][BCE] [G] A BCE[A][BCE][G] BB[BCE][BCE] [DG]CC D[G][H]DD[DG][DH]EE G[H][H]G H[DH][DH]HH注:带+号地结点为初始状态;带一号地结点为终止状态3- 07.给定下列自动机:其中:开始状态:0终止状态:2⑵确定化,得到DFAS42ehLvE3M+db从而可得DFA如图:a(2)此DFA地正则表达式为:(aa *b b)(b ab) 4-13.消除下列文法 G[E]地左递归.E-T I T—T/F I FI E ) I i解答:消除文法G[E]地左递归后得到:E T TE'E'T -TE'I £T T FT'T'T /FT' I £F T ( E) I i4-14.在LL(1)分析法中丄L分别代表什么含义答:第一个L代表从左到右地扫描,第二个 4-15.自顶向下分析思想是什么?答:从开始符出发导出句型并一个符号开始符号可推导出给定地终结符串4-16.自顶向下地缺点是什么?或 a b (b ab)L代表每次进行最左推导.个符号地与给定终结符串进行匹配.因此判定给定终结符号串是正确句子.如果全部匹配成功,则表示.jW1viftGw9答:在推导过程中,如果对文法不做限制.那么产生式地选择成为无根据地,只好一一去试所有可能地产生式,直至成功为止.这种方法地致命弱点是不断地回溯,大大影响速度.xSODOYWHLP4-17 .LL (1)文法地定义是什么?答:一个上下文无关文法是 LL(1)文法地充分必要条件是每个非终结符A地两个不同产生式,A T a ,A T 3 ;满足 SELECT(A T a ) A SELECT(A T 3 )=①.其中,a、3 不能同时二& . LOZMklqlOw4-18 .什么是文法地左递归?答:一个文法含有下列形式地产生式之一时:1)A T A3 , A€ VN 3 € V*2)A T B3 , B T Aa , A、B€ VN a、3 € V* 则称该文法是左递归地.4-19.递归下降法地主要思想是什么?答:对每个非终结符按其产生式结构写出相应语法分析子程序 •因为文法递归相应子程序也递归,子程序地结构与产生式结构几乎一致 •所以称此种方法称为递归子程序法或递归下降法 • ZKZUQsUJed 5- 19.自底向上分析法地原理是什么?答:在采用自左向右扫描,自底向上分析地前提下,该类分析方法是从输入符号串入手,通过反复查找当 前句型地句柄(最左简单短语),并使用文法地产生式把句柄归约成相应地非终极符来一步步地进行分析地•最终把输入串归约成文法地开始符号, 表明分析成功.dGY2mcoKtT5-23.给定文法 G[Z] : rCYbSWRLIA1. Z T C s2. C T if E then3. S T A = E 其中: Z 、C 、S A 、E € V N ;4. E T E V Aif 、then 、=、V 、 i € V T5. E T A6. A T i2. Follow(Z) = {#}Follow(C) = {i} Follow(S) = {#}Follow(E) = {#, V ,then}Follow(A) = { = ,# , V ,then } 则可构造ACTIONGOTO0 ifthe n=V i#Z CSEAS 3121OKa) 构造此文法地LR(0)项目集规范族,并给出识别活前缀地 b) 构造其SLR( 1)分析表. G 中加入产生式 0. Z' T Z, 解答:1.首先拓广文法:在TuWrUpPpf X Z ' T Z I 7: C T if E . then 7qWAq9jPqE Z T . C SE T E . V AC T . if E thenI 9 : S TA = . EI i : Z ' T Z . E T . E V A 12: Z T C . sE T . A S T . A = E A T . i A T . iI 10: C T if E then . 13: C T if . E thenI 11: E T E V . AE T . E V AA T . iE T . AI 12: S T A = E . A T . iE T E . V A I 4: Z T C S .I 13: E T E V A .15: S T A . = E 16: A T i .DFA.然后得到新地文法 ,再求G 地识别全部活前缀地 DFA FyXjoFIMWh2 S6 4 53 S6 7 84 r 15 S96 「6 r 6 「6 r 67 S10 S118 「5 「5 r 59 S6 12 810 「211 S6 1312 S11 r 313 「4 「4 r 45-24. 设有文法G[S]:S T a AA T AbA T b求识别该文法所有活前缀地DFA.llVIWTNQFk解答:(1).首先拓广文法:在G中加入产生式0.S ' T S,然后得到新地文法G0.S S1.S T aA2.A T Ab3.A T b(2).再求G地识别全部活前缀地DFA6-07.语法制导翻译方法地基本思想是什么答:在语法分析过程中,每当使用一条产生式进行推导或归约时,就执行该产生式所对应地语义动作进行属性计算,完成对输入符号串地翻译.yhUQsDgRTI6-08.何谓“语法制导翻译”?答:在语法分析过程中,随着分析地步步进展,根据每个产生式所对应地语义子程序(或语义规则描述地语义动作)进行翻译地办法称作语法制导翻译.MdUZYnKS8l6-09.在一个属性文法中,对应于每个产生式A T a都有一套与之相关联地语义规则,每条规则地形式为b: = f (c1,c2…,ck),其中对于b地要求是什么?答:语义规则中地左部属性变量b被规定为只能是下述两种变量:①对应产生式左部符号地综合属性变量;②对应产生式右部符号地继承属性变量.7-05.常用地中间语言种类有哪几种?答:有逆波兰式、三地址代码、抽象语法树和DAG.8-06.符号表地作用有哪些?答:在编译程序中符号表用来存放语言程序中出现地有关标识符地属性信息,这些信息集中反映了标识符地语义特征属性•起主要作用是:09T7t6eTno①收集符号属性;②上下文语义地合法性检查地依据;③作为目标代码生成阶段地址分配地依据•9-09 .运行时存储器地划分是怎样地?答:运行时存储器地划分如下图所示•10-07.简述优化地原则是什么?答:编译程序提供地对代码优化必须遵循地原则是:(1)等价原则.经过优化后不应改变程序运行地结果•(2)有效原则.使优化后所产生地目标代码运行时间较短,占用地存储空间较小(3)合算原则.应尽可能以较低地代价取得较好地优化效果.10-08 •简述常用地优化技术有哪些?答:编译程序中常用地优化技术有:(1) 删除公共子表示式;(2) 复写传播;(3) 删除无用代码;(4) 代码外提;(5) 强度削弱;(6) 删除归纳变量;(7) 合并常量.10-09.设有基本块:⑴ a:=b-c(2)d:=a+4(3)e:=a-b(4)f:=a+4(5)b:=b+c(6)c:=b-f(7)b:=b-c(8) f:=b+f (9) a:=a-f (1) 画出DAG 图;(2) 假设基本块出口时只有 解答:(1) 给出DAG 如右:(2) 重写三地址代码如下:a:=b-c d:=a+4 f:=de:=a-b b:=b+c c:=c+d b:=b-c f:=b-d a:=a+d10-10.何谓优化?按所涉及地程序范围可分为哪几级优化?答:优化:对程序进行各种等价变换,使得从变换后地程序出发,能产生更有效地目标代码三种级别:局部优化、循环优化、全局优化.e5TfZQIUB510-11.设有基本块「:= 2 T 2:= 10/T 1 T s := S — R T 4:= S + R A := T 2 * T 4 B := A T 5:= S + R T 6:= T 3 * T 5(1)画出 DAGS;A, B 还被引用,请写出优化后地三地址代码序列 .s1SovAcVQMT 4:= S+ Ra, b 还被引用,请写出优化后地三地址代码序列(2)假设基本块出口时只有 解:(1)DAG:见右图(2) 优化后地四元式10 +b9 +e6 5 ++ 324 1 4cb8 c7山 11^A:= 5*T4 B:= T3+ T4GXRw1kFW5s版权申明本文部分内容,包括文字、图片、以及设计等在网上搜集整理•版权为个人所有This article in eludes some parts, in cludi ng text, pictures, and desig n. Copyright is pers onal own ership. UTREX49%9用户可将本文地内容或服务用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律地规定,不得侵犯本网站及相关权利人地合法权利.除此以外,将本文任何内容或服务用于其他用途时,须征得本人及相关权利人地书面许可,并支付报酬.8PQN3NDYyPUsers mayuse the contents or services of this article for personal study, research or appreciation, and other non-commercial or non-profit purposes, but at the same time, they shall abide by the provisi ons of copyright law and other releva nt laws, and shall not infringe upon the legitimate rights of this website and its releva nt obligees. In additi on, when any content or service of this article is used for other purposes, writte n permissi on and remun erati on shall be obta ined from the pers on con cer ned and the releva nt obligee. mLPVzx7ZNw转载或引用本文内容必须是以新闻性或资料性公共免费信息为使用目地地合理、善意引用,不得对本文内容原意进行曲解、修改,并自负版权等法律责任.AHP35hB02dReproducti on or quotati on of the content of this article must be reas on able and good-faith citatio n for the use of n ews or in formative public free information. Itshall not misinterpret or modify the originalintention of the content of this article, and shall bear legal liabilitysuch as copyright. NDOCB14BT。
第一章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. xyxb. (xyx)*c. x n yx n(n≥0)d. x*yx*2、文法G描述的语言L(G)是指。
a. L(G)={α|S+⇒α , α∈V T*}b. L(G)={α|S*⇒α, α∈V T*}c. L(G)={α|S*⇒α,α∈(V T∪V N*)}d. L(G)={α|S+⇒α, α∈(V T∪V N*)}3、有限状态自动机能识别。
a. 上下文无关文法b. 上下文有关文法c.正规文法d. 短语文法4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立。
a. 若f(a)>g(b),则a>bb.若f(a)<g(b),则a<bc. a~b都不一定成立d. a~b一定成立5、如果文法G是无二义的,则它的任何句子α。
a. 最左推导和最右推导对应的语法树必定相同b. 最左推导和最右推导对应的语法树可能不同c. 最左推导和最右推导必定相同d. 可能存在两个不同的最左推导,但它们对应的语法树相同6、由文法的开始符经0步或多步推导产生的文法符号序列是。
第6章 属性文法和语法制导翻译7. 下列文法由开始符号S 产生一个二进制数,令综合属性val 给出该数的值:试设计求的属性文法,其中,已知B 的综合属性c, 给出由B 产生的二进位的结果值。
例如,输入时,=,其中第一个二进位的值是4,最后一个二进位的值是。
【答案】11. 设下列文法生成变量的类型说明:(1)构造一下翻译模式,把每个标识符的类型存入符号表;参考例。
【答案】第7章 语义分析和中间代码产生1. 给出下面表达式的逆波兰表示(后缀式):3. 请将表达式-(a+b)*(c+d)-(a+b+c)分别表示成三元式、间接三元式和四元式序列。
【答案】间接码表:(1)→(2)→(3)→(4)→(1)→(5)→(6)4. 按节所说的办法,写出下面赋值句A:=B*(-C+D) 的自下而上语法制导翻译过程。
给出所产生的三地址代码。
【答案】5. 按照7.3.2节所给的翻译模式,把下列赋值句翻译为三地址代码: A[i, j]:=B [i, j] + C[A [k, l]] + d [ i+j] 【答案】6. 按7.4.1和节的翻译办法,分别写出布尔式A or ( B and not (C or D) )的四元式序列。
【答案】用作数值计算时产生的四元式: 用作条件控制时产生的四元式:其中:右图中(1)和(8)为真出口,(4)(5)(7)为假出口。
7. 用7.5.1节的办法,把下面的语句翻译成四元式序列:While A<C and B<D do if A=1 then C:=C+1else while A ≦D do A:=A+2; 【答案】第9章 运行时存储空间组织4. 下面是一个Pascal 程序:当第二次( 递归地) 进入F 后,DISPLAY 的内容是什么当时整个运行栈的内容是什么 【答案】第1次进入F 后,运行栈的内容: 第2次进入F 后,运行栈的内容: 109 87 6 5 4 3 2 1 017 16 15 14 13 12 11 10 9 8 7第2次进入F 后,Display 内容为:5. 对如下的Pascal 程序,画出程序执行到(1)和(2)点时的运行栈。
(完整版)编译原理课后习题答案第一章1.典型的编译程序在逻辑功能上由哪几部分组成?答:编译程序主要由以下几个部分组成:词法分析、语法分析、语义分析、中间代码生成、中间代码优化、目标代码生成、错误处理、表格管理。
2. 实现编译程序的主要方法有哪些?答:主要有:转换法、移植法、自展法、自动生成法。
3. 将用户使用高级语言编写的程序翻译为可直接执行的机器语言程序有哪几种主要的方式?答:编译法、解释法。
4. 编译方式和解释方式的根本区别是什么?答:编译方式:是将源程序经编译得到可执行文件后,就可脱离源程序和编译程序单独执行,所以编译方式的效率高,执行速度快;解释方式:在执行时,必须源程序和解释程序同时参与才能运行,其不产生可执行程序文件,效率低,执行速度慢。
第二章1.乔姆斯基文法体系中将文法分为哪几类?文法的分类同程序设计语言的设计与实现关系如何?答:1)0型文法、1型文法、2型文法、3型文法。
2)2. 写一个文法,使其语言是偶整数的集合,每个偶整数不以0为前导。
答:Z→SME | BS→1|2|3|4|5|6|7|8|9M→ε | D | MDD→0|SB→2|4|6|8E→0|B3. 设文法G为:N→ D|NDD→ 0|1|2|3|4|5|6|7|8|9请给出句子123、301和75431的最右推导和最左推导。
答:N?ND?N3?ND3?N23?D23?123N?ND?NDD?DDD?1DD?12D?123N?ND?N1?ND1?N01?D01?301N?ND?NDD?DDD?3DD?30D?301N?ND?N1?ND1?N31?ND31?N431?ND431?N5431?D5431?7 5431N?ND?NDD?NDDD?NDDDD?DDDDD?7DDDD?75DDD?754 DD?7543D?75431 4. 证明文法S→iSeS|iS| i是二义性文法。
答:对于句型iiSeS存在两个不同的最左推导:S?iSeS?iiSesS?iS?iiSeS所以该文法是二义性文法。
《编译原理》第一次作业参考答案一、下列正则表达式定义了什么语言(用尽可能简短的自然语言描述)?1.b*(ab*ab*)*所有含有偶数个a的由a和b组成的字符串.2.c*a(a|c)*b(a|b|c)* | c*b(b|c)*a(a|b|c)*答案一:所有至少含有1个a和1个b的由a,b和c组成的字符串.答案二:所有含有子序列ab或子序列ba的由a,b和c组成的字符串.说明:答案一要比答案二更好,因为用自然语言描述是为了便于和非专业的人员交流,而非专业人员很可能不知道什么是“子序列”,所以相比较而言,答案一要更“自然”.二、设字母表∑={a,b},用正则表达式(只使用a,b, ,|,*,+,?)描述下列语言:1.不包含子串ab的所有字符串.b*a*2.不包含子串abb的所有字符串.b*(ab?)*3.不包含子序列abb的所有字符串.b*a*b?a*注意:关于子串(substring)和子序列(subsequence)的区别可以参考课本第119页方框中的内容.~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~《编译原理》第二次作业参考答案一、考虑以下NFA:1.这一NFA接受什么语言(用自然语言描述)?所有只含有字母a和b,并且a出现偶数次或b出现偶数次的字符串.2.构造接受同一语言的DFA.答案一(直接构造通常得到这一答案):答案二(由NFA构造DFA得到这一答案):二、正则语言补运算3.画出一个DFA,该DFA恰好识别所有不含011子串的所有二进制串.1.画出一个DFA,该DFA恰好识别所有不含011子串的所有二进制串.规律:构造语言L的补语言L’的DFA,可以先构造出接受L的DFA,再把这一DFA的接受状态改为非接受状态,非接受状态改为接受状态,就可以得到识别L’的DFA.说明:在上述两题中的D状态,无论输入什么符号,都不可能再到达接受状态,这样的状态称为“死状态”.在画DFA时,有时为了简明起见,“死状态”及其相应的弧(上图中的绿色部分)也可不画出.2.再证明:对任一正则表达式R,一定存在另一正则表达式R',使得L(R')是L(R)的补集.证明:根据正则表达式与DFA的等价性,一定存在识别语言L(R)的DFA. 设这一DFA为M,则将M的所有接受状态改为非接受状态,所有非接受状态改为接受状态,得到新的DFA M’. 易知M’识别语言L(R)的补集. 再由正则表达式与DFA的等价性知必存在正则表达式R’,使得L(R’)是L(R)的补集.三、设有一门小小语言仅含z、o、/(斜杠)3个符号,该语言中的一个注释由/o开始、以o/结束,并且注释禁止嵌套.1.请给出单个正则表达式,它仅与一个完整的注释匹配,除此之外不匹配任何其他串. 书写正则表达式时,要求仅使用最基本的正则表达式算子( ,|,*,+,?).参考答案一:/o(o*z|/)*o+/思路:基本思路是除了最后一个o/,在注释中不能出现o后面紧跟着/的情况;还有需要考虑的是最后一个o/之前也可以出现若干个o.参考答案二(梁晓聪、梁劲、梁伟斌等人提供):/o/*(z/*|o)*o/2.给出识别上述正则表达式所定义语言的确定有限自动机(DFA). 你可根据问题直接构造DFA,不必运用机械的算法从上一小题的正则表达式转换得到DFA.~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~《编译原理》第三次作业参考答案一、考虑以下DFA的状态迁移表,其中0,1为输入符号,A~H代表状态:其中A为初始状态,D为接受状态,请画出与此DFA等价的最小DFA,并在新的DFA状态中标明它对应的原DFA状态的子集.说明:有些同学没有画出状态H,因为无法从初始状态到达状态H. 从实用上讲,这是没有问题的. 不过,如果根据算法的步骤执行,最后是应该有状态H的.二、考虑所有含有3个状态(设为p,q,r)的DFA. 设只有r是接受状态. 至于哪一个状态是初始状态与本问题无关. 输入符号只有0和1. 这样的DFA总共有729种不同的状态迁移函数,因为对于每一状态和每一输入符号,可能迁移到3个状态中的一个,所以总共有3^6=729种可能. 在这729个DFA中,有多少个p和q是不可区分的(indistinguishable)?解释你的答案.解:考虑对于p和q,在输入符号为0时的情况,在这种情况下有5种可能使p和q无法区分:p和q在输入0时同时迁移到r(1种可能),或者p和q在输入0时,都迁移到p或q(4种可能).类似地,在输入符号为1时,也有5种可能使p和q无法区分.如果再考虑r的迁移,r的任何迁移对问题没有影响. 于是r在输入0和输入1时各有3种可能的迁移,总共有3*3=9种迁移.因此,总共有5*5*9=225个DFA,其中p和q是不可区分的.三、证明:所有仅含有字符a,且长度为素数的字符串组成的集合不是正则语言.证明:用反证法.假设含有素数个a的字符串组成的集合是正则语言,则必存在一个DFA接受这一语言,设此DFA为D. 由于D 的状态数有限,而素数有无限多个,所以必存在两个不同的素数p和q(设p<q),使得从D的初始状态出发,经过p个a和q个a后到达同一状态s,且s为接受状态. 由于DFA每一步的迁移都是确定的,所以从状态s 出发,经过(q-p)个a,只能到达状态s.考虑仅含有字母a,长度为p+p(q-p)的字符串T. T从初始状态出发,经过p个a到达状态s,再经过(q-p)个a仍然到达s;同样,经过p(q-p)个a后仍然到达s. 因此,从初始状态出发,经过p+p(q-p)个a后必然到达状态s. 由于p+p(q-p)=p(q-p+1)是合数,而s为接受状态,因而得出矛盾. 原命题得证.~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~《编译原理》第四次作业参考答案一、用上下文无关文法描述下列语言:1.定义在字母表∑={a, b}上,所有首字符和尾字符相同的非空字符串.S → aTa | bTb | a | bT → aT | bT | є说明:1. 用T来产生定义在字母表∑={a, b}上的任意字符串;2. 注意不要漏了单个a和单个b的情况.2.L={0i1j|i≤j≤2i且i≥0}.S → 0S1 | 0S11 | є3.定义在字母表∑={0, 1}上,所有含有相同个数的0和1的字符串(包括空串).S → 0S1 | 1S0 | SS | є思路:分两种情况考虑.1)如果首尾字母不同,那么这一字符串去掉首尾字母仍应该属于我们要定义的语言,因此有S → 0S1 | 1S0;2)如果首尾字母相同,那么这一字符串必定可以分成两部分,每一部分都属于我们要定义的语言,因此有S → SS.二、考虑以下文法:S → aABeA → Abc|bB → d1.用最左推导(leftmost derivation)推导出句子abbcde.S ==> aABe ==> aAbcBe ==> abbcBe ==> abbcde2.用最右推导(rightmost derivation)推导出句子abbcde.S ==> aABe ==> aAde ==> aAbcde ==> abbcde3.画出句子abbcde对应的分析树(parse tree).三、考虑以下文法:S → aSbS → aSS →1.这一文法产生什么语言(用自然语言描述)?所有n个a后紧接m个b,且n>=m的字符串.2.证明这一文法是二义的.对于输入串aab,有如下两棵不同的分析树3.写出一个新的文法,要求新文法无二义且和上述文法产生相同的语言.答案一:S → aSb | TT → aT | ε答案二:S → TS’T → aT | εS’→ aS’b | ε~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~《编译原理》第五次作业参考答案一、考虑以下文法:S → aTUV | bVT → U | UUU →ε | bVV →ε | cV写出每个非终端符号的FIRST集和FOLLOW集.FIRST(S)={a, b} FIRST(T)={є, b} FIRST(U)={ є, b} FIRST(V)={є, c}FOLLOW(S)={$} FOLLOW(T)={ b, c, $} FOLLOW(U)={ b, c, $} FOLLOW(V)={b, c , $}二、考虑以下文法:S → (L) | aL → L, S | S1.消除文法的左递归.S → (L) | aL → SL’L’→ ,SL’ | ε2.构造文法的LL(1)分析表.FIRST(S) = {‘(‘, ‘a’} FIRST(L) = {‘(‘, ‘a’} FIRST(L’) = {‘,’, ε}FOLLOW(S) = {‘$’, ‘,’, ‘)’} FOLLOW(L) = {‘)’ } FOLLOW(L’) = {‘)’}3.三、考虑以下文法:S → aSbS | bSaS | ε这一文法是否是LL(1)文法?给出理由.这一文法不是LL(1)文法,因为S有产生式S →ε,但FIRST(S) = {a, b, ε},FOLLOW(S) = {a, b},因而FIRST(S)∩FOLLOW(S)≠∅. 根据LL(1)文法的定义知这一文法不是LL(1)文法.~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~《编译原理》第六次作业参考答案一、考虑以下文法:(0) E’→ E(1) E → E+T(2) E → T(3) T → TF(4) T → F(5) F → F*(6) F → a(7) F → b1. 写出每个非终端符号的FIRST集和FOLLOW集.FIRST(E’)= FIRST(E)= FIRST(T)= FIRST(F)={a, b}FOLLOW(E’)={$} FOLLOW(E)={+, $} FOLLOW(T)={+, $, a, b} FOLLOW(F)= {+, *, $, a, b}2. 构造识别这一文法所有活前缀(viable prefixes)的LR(0) 自动机(参照课本4.6.2节图4.31).~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~ ~\(≧▽≦)/~《编译原理》第八次作业参考答案一、考虑以下语法制导定义(Syntax Directed Definition):对于输入串gbbabbccd构造带注释的分析树(annotated parse tree).最终答案:34二、以下文法定义了二进制浮点数常量的语法规则:S → L.L | LL → LB | BB → 0 | 1试给出一个S属性的语法制导定义,其作用是求出该二进制浮点数的十进制值,并存放在开始符号S相关联的一个综合属性value中。