《编译原理复习题(考试).doc》由会员分享,可在线阅读,更多相关《编译原理复习题(考试).doc(16页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、如有侵权,请联系网站删除,仅供学习与交流编译原理复习题(考试)【精品文档】第 16 页编译原理复习题一、是非题1计算机高级语言翻译成低级语言只有解释一种方式。()3每个文法都能改写为 LL(1) 文法。 ()4算符优先关系表不一定存在对应的优先函数。 ()5LR分析方法是自顶向下语法分析方法。 ()6“ 用高级语言书写的源程序都必须通过编译,产生目标代码后才能投入运行 ”这种说法。( )7一个句型的句柄一定是文法某产生式的右部。 ()8仅考虑一个基本块,不能确定一个赋值是否真是无用的。 ( )9在中间代码优化中循环上的优化主要有不变表达式外提和削减运算强度。 ( )10对于数据空间的存贮分配,
2、FORTRAN采用动态贮存分配策略。()11甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。( )12递归下降分析法是自顶向下分析方法。( )13产生式是用于定义词法成分 的一种书写规则。 ()14在 SLR(1)分析法的名称中,S的含义是简单的。()15综合属性是用于 “ 自上而下 ” 传递信息。( )16符号表中的信息栏中登记了每个名字的属性和特征等有关信息,如类型、种属、所占单元大小、地址等等。 ()17程序语言的语言处理程序是一种应用软件。 ()18解释程序适用于 COBOL 和 FORTRAN 语言。 ()19一个 LL(l)文法一定是无二义的。 (
3、)20正规文法产生的语言都可以用上下文无关文法来描述。 ()21一张转换图只包含有限个状态,其中有一个被认为是初态,最多只有一个终态。 ()22目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 ()22逆波兰法表示的表达式亦称后缀式 。 ( )23如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义的。 ( )24数组元素的地址计算与数组的存储方式有关。()25算符优先关系表不一定存在对应的优先函数。 ()26编译程序是对高级语言程序的解释执行。( )27一个有限状态自动机中,有且仅有一个唯一的终态。()28一个算符优先文法可能不存在算符优先函数与之对应。 ( )29语法分
4、析时必须先消除文法中的左递归 。 ()30LR分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错地点。 ()31逆波兰表示法表示表达式时无须使用括号。 ( )32静态数组的存储空间可以在编译时确定。 ()33进行代码优化时应着重考虑循环的代码优化,这对提高目标代码的效率将起更大作用。 ()34两个正规集相等的必要条件是他们对应的正规式等价。 ()35一个语义子程序描述了一个文法所对应的翻译工作。 ()36设r和s分别是正规式,则有L(r|s)=L(r)L(s)。()37确定的自动机以及不确定的自动机都能正确地识别正规集。()38词法分析作为单独的一遍来处理较好。 ( )39构造LR
5、分析器的任务就是产生LR分析表。 ()40规范归约和规范推导是互逆的两个过程。 ()41同心集的合并有可能产生新的“移进”/“归约”冲突。 ( )42LR分析技术无法适用二义文法。 ( )43树形表示和四元式不便于优化,而三元式和间接三元式则便于优化。 ()44程序中的表达式语句在语义翻译时不需要回填技术。 ()45对中间代码的优化依赖于具体的计算机。 ( )46若一个句型中出现了某产生式的右部,则此右部一定是该句型的句柄。()47在程序中标识符的出现仅为使用性的。()48削减运算强度破坏了临时变量在一基本块内仅被定义一次的特性。()49编译程序与具体的机器有关,与具体的语言无关。()二、选择
6、题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)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
7、型、3型。其中3型文法是( B )。A.短语文法 B正则文法C上下文有关文法 D上下文无关文法6 通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括( C )。A模拟执行器B解释器 C表格处理和出错处理 D符号执行器7 一个句型中的最左( B )称为该句型的句柄。A短语 B简单短语 C素短语 D终结符号 8 文法 GE :ETE TTFT FFa ( E )该文法句型 E F (E T) 的简单短语是下列符号串中的( B )。 ( E T ) E T F F (E T) A 和 B 和 C 和 D 9 词法分析器用于识别( C )。A句子
8、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都不对15 ( B )和代码优化部分不是每个编
9、译程序都必需的。A语法分析B中间代码生成C词法分析 D目标代码生成 16( B )是两类程序语言处理程序。 A高级语言程序和低级语言程序B解释程序和编译程序 C编译程序和操作系统D系统程序和应用程序 17 数组的内情向量中肯定不含有数组的( D )的信息。A维数 B类型 C维上下界 D各维的界差 18. 一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组( D )。 A句子 B句型C单词 D产生式19 文法分为四种类型,即0型、1型、2型、3型。其中2型文法是( D )。A短语文法 B正则文法 C上下文有关文法D上下文无关文法20文法 G 所
10、描述的语言是( C )的集合。 A文法 G 的字母表 V 中所有符号组成的符号串B文法 G 的字母表 V 的闭包 V* 中的所有符号串C由文法的开始符号推出的所有终极符串D由文法的开始符号推出的所有符号串21词法分析器用于识别( C )。 A字符串 B语句C单词 D标识符22文法分为四种类型,即0型、1型、2型、3型。其中0型文法是( A )。A短语文法 B正则文法 C上下文有关文法 D上下文无关文法24( A )是一种典型的解释型语言。 ABASIC BC CFORTRAN DPASCAL25与编译系统相比,解释系统( D )。A比较简单 , 可移植性好 , 执行速度快 B比较复杂 , 可移
11、植性好 , 执行速度快C比较简单 , 可移植性差 , 执行速度慢 D比较简单 , 可移植性好 , 执行速度慢 26用高级语言编写的程序经编译后产生的程序叫( B )。 A源程序B目标程序C连接程序 D解释程序27词法分析器用于识别( A )。 A字符串 B语句 C单词 D标识符 28编写一个计算机高级语言的源程序后 , 到正式上机运行之前,一般要经过( B )这几步: (1) 编辑 (2) 编译 (3) 连接 (4) 运行 A(1)(2)(3)(4) B(1)(2)(3) C(1)(3)D(1)(4)29把汇编语言程序翻译成机器可执行的目标程序的工作是由( B )完成的。A编译器 B汇编器 C
12、解释器 D预处理器31词法分析器的输出结果是( C )。A单词的种别编码 B单词在符号表中的位置C单词的种别编码和自身值 D单词自身值32 正规式 M 1 和 M 2 等价是指( C )。 AM1和M2的状态数相等BM1和M2的有向边条数相等CM1和M2所识别的语言集相等DM1和M2状态数和有向边条数相等 33 文法G:SxSx|y所识别的语言是( C )。Axyx B(xyx)* C Dx*yx* 34如果文法G是无二义的,则它的任何句子 ( A )。A最左推导和最右推导对应的语法树必定相同 B最左推导和最右推导对应的语法树可能不同C最左推导和最右推导必定相同 D可能存在两个不同的最左推导,
13、但它们对应的语法树相同 35构造编译程序应掌握( D )。A源程序B目标语言C编译方法 D以上三项都是36四元式之间的联系是通过( B )实现的。 A指示器 B临时变量C符号表 D程序变量 37表达式(AB)(CD)的逆波兰表示为( B )。AABCD BABCD CABCD DABCD 38. 优化可生成( D )的目标代码。A运行时间较短B占用存储空间较小C运行时间短但占用内存空间大 D运行时间短且占用存储空间小39下列( C )优化方法不是针对循环优化进行的。A强度削弱 B删除归纳变量 C删除多余运算 D代码外提40编译程序使用( B )区别标识符的作用域。 A说明标识符的过程或函数名B
14、说明标识符的过程或函数的静态层次C说明标识符的过程或函数的动态层次 D标识符的行号41编译程序绝大多数时间花在( D )上。A出错处理 B词法分析 C目标代码生成 D表格管理42 编译程序是对( D )。 A汇编程序的翻译 B高级语言程序的解释执行C机器语言的执行 D高级语言的翻译 43 采用自上而下分析,必须( C )。A消除左递归 B消除右递归C消除回溯 D提取公共左因子 44在规范归约中,用( B )来刻画可归约串。A直接短语 B句柄C最左素短语 D素短语 45 若a为终结符,则A- a为( B ) 项目。A归约B移进 C接受 D待约 46间接三元式表示法的优点为( A )。 A采用间接
15、码表,便于优化处理B节省存储空间,不便于表的修改C便于优化处理,节省存储空间 D节省存储空间,不便于优化处理 47基本块内的优化为( B )。A代码外提,删除归纳变量B删除多余运算,删除无用赋值C强度削弱,代码外提D循环展开,循环合并48. 在目标代码生成阶段,符号表用( D )。A目标代码生成 B语义检查C语法检查 D地址分配49若项目集Ik含有A- ,则在状态k时,仅当面临的输入符号aFOLLOW(A)时,才采取“A- ”动作的一定是( D )。ALALR文法 BLR(0)文法 CLR(1)文法DSLR(1)文法50堆式动态分配申请和释放存储空间遵守( D )原则。 A先请先放 B先请后放
16、C后请先放 D任意三、填空题1编译程序的工作过程一般可以划分为词法分析,语法分析,语义分析,中间代码生成,代码优化等几个基本阶段,同时还会伴有_表格处理_和 _出错处理_。 2编译方式与解释方式的根本区别在于_是否生成目标代码_。3产生式是用于定义_语法成分_的一种书写规则。 4设G是一个给定的文法,S是文法的开始符号,如果S-x( 其中 xVT*), 则称 x是文法的一个_句子_。 5自顶向下的语法分析方法的基本思想是:从文法的_开始符号_开始,根据给定的输入串并按照文法的产生式一步一步的向下进行_直接推导_,试图推导出文法的_句子_,使之与给定的输入串_匹配_。 6常用的参数传递方式有_传
17、地址_,传值和传名。 7一个句型中的最左简单短语称为该句型的_句柄_。 8对于文法的每个产生式都配备了一组属性的计算规则,称为 _语义规则_ 。9一个典型的编译程序中,不仅包括_词法分析_、_语法分析_、_中间代码生成_、代码优化、目标代码生成等五个部分,还应包括表格处理和出错处理。10 从功能上说,程序语言的语句大体可分为_执行性_语句和_说明性_语句两大类。11 扫描器的任务是从_源程序_中识别出一个个_单词符号_。 12 产生式是用于定义_语法范畴_的一种书写规则。13语法分析是依据语言的_语法_规则进行的,中间代码产生是依据语言的_语义_规进行的。14语法分析器的输入是_单词符号串_,
18、其输出是_语法单位_。15一个名字的属性包括_类型_和_作用域_。16逆波兰式 ab+c+ d*e- 所表达的表达式为_(a+b+c)*d-e_ 。 17语法分析最常用的两类方法是_自上而下_和_自下而上_分析法。18计算机执行用高级语言编写的程序主要有两种途径:_解释_和_编译_。 19扫描器是_词法分析器_,它接受输入的_源程序_,对源程序进行_词法分析_并识别出一个个单词符号,其输出结果是单词符号,供语法分析器使用。20自上而下分析法采用_移进_、归约、错误处理、_接受_等四种操作。21一个LR分析器包括两部分:一个总控程序和_一张分析表_。22后缀式abc-/所代表的表达式是_a/(b
19、-c)_。 23局部优化是在_基本块_范围内进行的一种优化。24词法分析基于_正则_文法进行,即识别的单词是该类文法的句子。 25语法分析基于_上下文无关_文法进行,即识别的是该类文法的句子。语法分析的有效工具是_语法树_。26分析句型时,应用算符优先分析技术时,每步被直接归约的是_最左素短语_,而应用LR分析技术时,每步被直接归约的是_句柄_。27语义分析阶段所生成的与源程序等价的中间表示形式可以有_逆波兰_、_四无式表示_与_三元式表示_等。28按Chomsky分类法,文法按照_规则定义的形式_进行分类。 29一个文法能用有穷多个规则描述无穷的符号串集合(语言)是因为文法中存在有_递归_定
20、义的规则。四、简答题111. 写一文法,使其语言是偶正整数的集合,要求: (1)允许0打头;(2) 不允许0打头。解:(1)GS=(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)GS=(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 解1(0|1)*101对应的NFA为 3.
21、 写出表达式(ab*c)/(ab)d的逆波兰表示和三元式序列。逆波兰表示: abc*ab/d三元式序列: (*,b,c) (,a,) (,a,b) (,d)4. 已知文法 GS 为:SdAB AaA|aBBb|GS 产生的语言是什么? 答:GS产生的语言是L(GS)=。5. 构造正规式相应的 DFA : 1(1010 * | 1(010) * 1) * 0。解:1(1010 * | 1(010) * 1) * 0对应的NFA为:6. 已知文法G(S) Sa|(T) TT,S|S 写出句子(a,a),a)的规范归约过程及每一步的句柄。解:句型归约规则 句柄 (a,a),a)Saa(S,a),a)
22、TSS (T,a),a)Saa(T,S),a)TT,S T,S(S),a) TSS(T),a) SS(T) (T)(S,a) TSS(T,a) Saa(T,S) TT,S T,S(T) S(T) (T)S7. 写一个文法,使其语言是奇数集,且每个奇数不以0开头。解:文法G(N):NAB|BAAC|DB1|3|5|7|9DB|2|4|6|8C0|D8. 设文法G(S): S(L)|a S|a LL,S|S (1) 消除左递归和回溯;(2) 计算每个非终结符的FIRST和FOLLOW。解:(1) S(L)|aS SS| LSL LSL| (2) FIRST)S)(,aFOLLOW(S)#,) FI
23、RST(S),a,FOLLOW(S)#,)FIRST(L)(,aFOLLOW(L) ) FIRST(L),FOLLOW(L )9. 已知文法G(E) ET|ET TF|T *F F(E)|i (1)给出句型(T *Fi)的最右推导; (2)给出句型(T *Fi)的短语、素短语。解:(1) 最右推导: E=T-F=(E)-(ET)=(EF)-(Ei)=(Ti)=(T*Fi)(2) 短语:(T*Fi),T*Fi,T*F,i素短语:T*F,i 10. Whilea0 b0do Begin X:X1; if a0 then a:a1 else b:b1 End; 翻译成四元式序列。解: (1) (j,
24、a,0,5) (2) (j,3) (3) (j,b,0,5) (4) (j,15) (5) (,X,1,T1) (6) (:,T1,X) (7) (j,a,0,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)for j:=1 to 10 do aj + j:=0。答: (1)100: t1:=a+b 101: t2:=6*t1 102: t3:=5+t2 (2)
25、100: j:=1 101: if j10 goto NEXT 102: i:=j+j 103: ai:=012. 设基本块p由如下语句构成: T 0 : =3.14; T 1 :=2*T 0 ; T 2 :=R+r; A:=T l *T 2 ; B:=A; T 3 :=2*T 0 ; T 4 :=R+r; T 5 :=T 3 *T 4 ; T 6 :=R-r ; B:=T 5 *T 6 ;试给出基本块p的 DAG 。解:基本块p的DAG图: 1234+-*T03.14T1,T36.28RrT2,T4T6A,T5B13. 写出表达式(a+b)/(a-b-(a+b*c)的三元序列及四元序列。解:
26、(1)三元式:(,a,b)(,a,b)(*,b,c)(,a,)(2)四元式:(,a,b,T1)(,a,b,T2)(/,T1,T2,T3)(*,b,c,T4)(,a,T4,T5)(,T3,T5,T6)14. 写一个文法使其语言为偶数集,且每个偶数不以0开头。 解:文法G(S):SAB|B|A0 AAD|C B2|4|6|8 C1|3|5|7|9|B D0|C15. 设文法 G ( S ): SS aF|aF| aF F*aF|*a (1)消除左递归和回溯;(2)构造相应的 FIRST 和 Follow 集合。解:(1) S-aFS|aFS S-aFS| F-*aF F-F| (2)FIRST(S
27、)a,+ FOLLOW(S)FIRST(S)+, FOLLOW(S)FIRST(F)* FOLLoW(F)(+, FIRST(F)*, FOLLOW(+,16. 简要说明语义分析的基本功能。答:语义分析的基本功能包括: 确定类型、类型检查、语义处理和某些静态语义检 查。17. 考虑文法 GS: S (T) | a+S | a T T,S | S 消除文法的左递归及提取公共左因子。解:消除文法GS的左递归:S(T) | a+S | a TST T,ST| 提取公共左因子: S(T) | aS S+S | TST T,ST| 18. 试为表达式 w+(a+b)*(c+d/(e-10)+8) 写出相
28、应的逆波兰表示。解: w a b + c d e 10 - / + 8 + * +19. 按照三种基本控制结构文法将下面的语句翻译成四元式序列:while (AC BD) if (A 1) C=C+1;else while (A D)A=A+2;解:该语句的四元式序列如下(其中E1、E2和E3分别对应ACBD、A1和AD,并且关系运算符优先级高):100 (j,A,C,102) 101 (j,_,_,113) 102 (jAc|aB A-ab B-bc 写出 L(GS) 的全部元素。解:S=Ac=abc 或S=aB=abc 所以L(GS)=abc22. 构造正规式 1(0|1)*101 相应的
29、DFA。解:先构造NFA:确定化: 重新命名,令AB为B、AC为C、ABY为D得: 所以,可得DFA为: 23. 文法 S-a|(T) T-T,S|S 对 (a,(a,a) 和 (a,a),(a),a) 的最左推导。解: 对(a,(a,a)的最左推导为: S=(T) =(T,S) =(S,S) =(a,S) =(a,(T) =(a,(T,S) =(a,(S,S) =(a,(a,S) =(a,(a,a) 对(a,a),(a),a) 的最左推导为: S=(T) =(T,S) =(S,S) =(T),S) =(T,S),S) =(T,S,S),S) =(S,S,S),S) =(T),S,S),S)
30、=(T,S),S,S),S) =(S,S),S,S),S) =(a,S),S,S),S) =(a,a),S,S),S) =(a,a),S),S) =(a,a),(T),S) =(a,a),(S),S) =(a,a),(a),S) =(a,a),(a),a)24. 文法: S-MH|a H-LSo| K-dML| L-eHf M-K|bLM 判断 G 是否为 LL(1) 文法,如果是,构造 LL(1) 分析表。解:各符号的FIRST集和FOLLOW集为: 预测分析表为:由于预测分析表中无多重入口,所以可判定文法是LL(1)的。25叙述由下列正规式描述的语言(a)0(0|1)*0(b)(|0)1*
31、)*(c)(0|1)*0(0|1)(0|1)(d)0*10*10*10*(e)(00|11)*(01|10)(00|11)*(01|10)(00|11)*)*解:(a)以0开头、以0结尾的所有0和1的串。(b)由0和1组成的串,包括空串。(c)倒数第3个字符为0,由0和1组成的串。(d)含有3个1的所有0和1的串。(e)由偶数个0和偶数个1构成的所有0和1的串。26已知文法GS:S(L)|aLL,S|S为句子(a,(a,a)构造最左推导和最右推导。解:句子(a,(a,a)的最左推导为:S=(L)=(L,S) =(S,S)=(a,S) =(a,(L)=(a,(L,S) =(a,(S,S)=(a,
32、(a,S)=(a,(a,a)句子(a,(a,a)的最右推导为:S=(L)=(L,S) =(l,(L)=(L,(L,S)=(L,(L,a)=(L,(S,a)=(L,(a,a)=(S,(a,a)=(a,(a,a)五.计算题1构造下述文法 GS 的自动机: S-A0 A-A0|S1|0 该自动机是确定的吗?若不确定,则对它确定化。解:由于该文法的产生式S-A0,A-A0|S1中没有字符集VT的输入,所以不是确定的自动机。 要将其他确定化,必须先用代入法得到它对应的正规式。把S?A0代入产生式A?S1有:A=A0|A01|0=A(0|01)|0=0(0|01)*。 代入S-A0有该文法的正规式:0(0
33、|01)*0,所以,改写该文法为确定的自动机为: 由于状态A有3次输入0的重复输入,所以上图只是NFA,下面将它确定化:下表由子集法将NFA转换为DFA: 由上表可知DFA为:2对下面的文法 G : E-TE E-+E| T-FT T -T| F- PF F- *F| P-(E)|a|b| (1)计算这个文法的每个非终结符的 FIRST 集和 FOLLOW 集。 (2) 证明这个方法是 LL(1) 的。 (3) 构造它的预测分析表。 解:(1)计算这个文法的每个非终结符的FIRST集和FOLLOW集。 FIRST集合有: FIRST(E)=FIRST(T)=FIRST(F)=FIRST(P)=
34、(,a,b,; FIRST(E)=+, FIRST(T)=FIRST(F)=FIRST(P)=(,a,b,; FIRST(T)=FIRST(T)=(,a,b,; FIRST(F)=FIRST(P)=(,a,b,; FIRST(F)=FIRST(P)=*,; FIRST(P)=(,a,b,; FOLLOW集合有: FOLLOW(E)=),#; FOLLOW(E)=FOLLOW(E)=),#; FOLLOW(T)=FIRST(E)FOLLOW(E)=+,),#;/不包含 FOLLOW(T)=FOLLOW(T)=FIRST(E)FOLLOW(E)=+,),#; FOLLOW(F)=FIRST(T)F
35、OLLOW(T)=(,a,b,+,),#;/不包含 FOLLOW(F)=FOLLOW(F)=FIRST(T)FOLLOW(T)=(,a,b,+,),#; FOLLOW(P)=FIRST(F)FOLLOW(F)=*,(,a,b,+,),#;/不包含 (2)证明这个方法是LL(1)的。 各产生式的SELECT集合有: SELECT(E-TE)=FIRST(T)=(,a,b,; SELECT(E-+E)=+; SELECT(E-)=FOLLOW(E/)=),# SELECT(T-FT)=FIRST(F)=(,a,b,; SELECT(T-T)=FIRST(T)=(,a,b,; SELECT(T-)=
36、FOLLOW(T/)=+,),#; SELECT(F-PF)=FIRST(P)=(,a,b,; SELECT(F-*F)=*; SELECT(F-)=FOLLOW(F)=(,a,b,+,),#; SELECT(P-(E)=( SELECT(P-a)=a SELECT(P-b)=b SELECT(P-)= 可见,相同左部产生式的SELECT集的交集均为空,所以文法GE是LL(1)文法。 (3)构造它的预测分析表。 文法GE的预测分析表如下: 3已知 NFA= ( x,y,z,0,1,M,x,z ),其中:M(x,0)=z,M(y,0)=x,y,M(z,0)=x,z,M(x,1)=x, M(y,1
37、)= ,M(z,1)=y, 构造相应的DFA并最小化。 解:根据题意有NFA图: 下表由子集法将NFA转换为DFA: 下面将该DFA最小化: (1) 首先将它的状态集分成两个子集:P1=A,D,E,P2=B,C,F (2) 区分P2:由于F(F,1)=F(C,1)=E,F(F,0)=F并且F(C,0)=C,所以F,C等价。由于F(B,0)=F(C,0)=C, F(B,1)=D,F(C,1)=E,而D,E不等价(见下步),从而B与C,F可以区分。有P21=C,F,P22=B。 (3) 区分P1:由于A,E输入0到终态,而D输入0不到终态,所以D与A,E可以区分,有P11=A,E,P12=D。 (4) 由于F(A,0)=B,F(E,0)=F,而B,F不等价,所以A,E可以区分。 (5) 综上所述,DFA可以区分为P=A,B,D,E,C,F。所以最小化的DFA如下: 4已知文法为: S-a|(T) T-T,S|S 构造它的 LR(0)分析表。 解:加入非终结符S,方法的增广文法为: S-S S-a S- S-(T) T-T,S T-S 下面构造
限制150内