西电编译原理_总复习
编译原理总复习概要

11
第5章 自顶向下语法分析方法
1、SELECT集的求法 SELECT集的求法
对给定的上下文无关文法的产生式A→α, 对给定的上下文无关文法的产生式A→α,A∈VN, A→α α∈V*, α∈V*, 若α≠>*ε, 则 SELECT(A→α)=FIRST(α) 若α=>*ε, 则 SELECT(A→α) =(FIRST(α)=(FIRST(α)-{ε})∪FOLLOW(A)
19
LR分析法 第7章 LR分析法
1、LR分析法 LR分析法
基本思想:根据当前分析栈中的符号串( 基本思想:根据当前分析栈中的符号串(通常 以状态表示)和向右顺序查看输入串的K 以状态表示)和向右顺序查看输入串的K个 K>=0)符号就可唯一地确定句柄 可唯一地确定句柄。 (K>=0)符号就可唯一地确定句柄。 LR分析是一种规范归约。 分析是一种规范归约 LR分析是一种规范归约。 LR分析法每次归约的是句柄。 分析法每次归约的是句柄 LR分析法每次归约的是句柄。
18
注意:分析到最后分析栈和剩余输入串均为#才接受! 注意:分析到最后分析栈和剩余输入串均为#才接受!
第6章 自底向上优先分析法
1、算符优先分析法的思想
基本思想:只定义文法中终结符之间的优先关 基本思想:只定义文法中终结符之间的优先关 终结符 不考虑非终结符), ),并由这种关系指导分 系(不考虑非终结符),并由这种关系指导分 析过程。 析过程。 算符优先法每次归约最左素短语而不是句柄。 最左素短语而不是句柄 算符优先法每次归约最左素短语而不是句柄。
6
第3章 文法和语言
3、句型、句子、短语、直接短语、句柄的含义 句型、句子、短语、直接短语、
表现在语法树中: 表现在语法树中:
编译原理复习文档

编译原理复习总结⏹题型:填空、选择、简答题、综合题第一章编译器概述复习要点:1、编译程序的总框架,编译程序工作的大致过程。
2、理解一下概念:编译、解释、翻译、编译前端、后端、遍⏹计算机执行用高级语言编写的程序主要有两种途径:解释和编译⏹编译:专指由高级语言转换为低级语言⏹编译和解释的区别:是否产生目标程序⏹编译程序的五个阶段:词法分析、语法分析、语义分析和中间代码生成、优化、目标代码生成⏹此外还包括:表格处理和出错处理第二章词法分析复习要点:1、了解词法分析器的任务2、掌握状态转换图3、正规式:与正规集的转换,判断等价4、有限自动机:NFA确定化、DFA最简化、正规式到DFA的转换⏹词法分析器(扫描器)的任务:从源程序中识别出一个个具有独立含义的最小语法单位。
⏹扫描器的输出格式:二元式序列(单词种别,单词符号的属性值)⏹状态转换图:结点代表状态,用圆圈○表示。
状态之间用箭弧→连结,弧上的标记指明在射出弧的结点状态下可能出现的输入字符初始状态接受状态⏹正规式和有限自动机●正规式和正规集的转换●给出正规式,要求写出相应的NFA、DFA●给出正规集,要求写出相应的NFA、DFA1、正规式和正规集●三种运算:“∣”读为“或”,“∙”读为“连接”“*”读为“闭包”●转换●正规式等价:两个正规式所表示的正规集相同,则称两个正规式等价令Σ是一个有限字母表,则Σ上的正规式及其表示的集合递归定义如下:1. ε和∅都是Σ上正规式,它们表示的正规集为{ε}和∅2. 若a是Σ上的字符,则a是正规式,它表示的正规集为{a}3. 若r和s都是Σ上的正规式,他们表示的正规集记为L(r)和L(s),则(a)r|s是正规式,表示集合L(r)∪L(s),(b)rs是正规式,表示集合L(r)L(s),(c)r*是正规式,表示集合(L(r))*,(d)(r)是正规式,表示的集合仍然是L(r)。
(加括弧改变优先级、结合性)⏹有限自动机1、确定的有限自动机M=(S,Σ,δ,S0,F)其中:1. S —有穷状态集2. Σ—输入字母表3. δ—映射函数(也称状态转换函数) S×Σ→S δ(s,a)=S‟ , S, S‟ ∈S, a∈Σ4. s0 —唯一的初始状态s0 ∈S5. F—终止状态集Z⊆S2、不确定的有限自动机M= (S, Σ,δ,S0, F) 其中:1. S —有限状态集(非终极符集合);2. Σ—输入字母表(终极符集合);3. δ—转换函数S ⨯ (⋃∑{ε}) →P(S),即S ⨯∑*到S的幂集(2S)的一种映射;4. S0 —唯一的初始状态集合(非空)S0∈S5. F—终止状态集合F⊆SDFA是NFA的特例,对于每个NFA M存在一个DFA M”,使L(M)=L(M”)。
编译原理期末总结复习

编译原理期末总结复习编译原理期末总结复习篇一:一、简答题1.什么是编译程序?答:编译程序是一种将高级语言程序(源程序)翻译成低级语言(目标程序)的程序。
将高级程序设计语言程序翻译成逻辑上等价的低级语言(汇编语言,机器语言)程序的翻译程序。
2.请写出文法的形式定义?答:一个文法G抽象地表示为四元组 G=(Vn,Vt,P,S)–其中Vn表示非终结符号– Vt表示终结符号,Vn∪Vt=V(字母表),Vn∩Vt=φ– S是开始符号,–P是产生式,形如:α→β(α∈V+且至少含有一个非终结符号,β∈V*)3.语法分析阶段的功能是什么?答:在词法分析的基础上,根据语言的语法规则,将单词符号串分解成各类语法短语(例:程序、语句、表达式)。
确定整个输入串是否构成语法上正确的程序。
4.局部优化有哪些常用的技术?答:优化技术1—删除公共子表达式优化技术2—复写传播优化技术3—删除无用代码优化技术4—对程序进行代数恒等变换(降低运算强度)优化技术5—代码外提优化技术6—强度削弱优化技术7—删除归纳变量优化技术简介——对程序进行代数恒等变换(代数简化)优化技术简介——对程序进行代数恒等变换(合并已知量)5.编译过程分哪几个阶段?答:逻辑上分五个阶段:词法分析、语法分析、语义分析与中间代码生成、代码优化、目标代码生成。
每个阶段把源程序从一种表示变换成另一种表示。
6. 什么是文法?答:文法是描述语言的语法结构的形式规则。
是一种工具,它可用于严格定义句子的结构;用有穷的规则刻划无穷的集合;文法是被用来精确而无歧义地描述语言的句子的构成方式;文法描述语言的时候不考虑语言的含义。
7. 语义分析阶段的功能是什么?答:对语法分析所识别出的各类语法范畴分析其含义,进行初步的翻译(翻译成中间代码);并对静态语义进行审查。
8.代码优化须遵循哪些原则?答:等价原则:不改变运行结果有效原则:优化后时间更短,占用空间更少合算原则:应用较低的代价取得较好的优化效果9.词法分析阶段的功能是什么?答:逐个读入源程序字符并按照构词规则切分成一系列单词任务:读入源程序,输出单词符号—滤掉空格,跳过注释、换行符—追踪换行标志,指出源程序出错的行列位置—宏展开,……10.什么是符号表?答:符号表在编译程序工作的过程中需要不断收集、记录和使用源程序中一些语法符号的类型和特征等相关信息。
编译原理总复习

编译原理总复习总复习■第1章1、编译程序是⼀种翻译程序,它将⾼级语⾔所写的源程序翻译成等价的机器语⾔或者汇编语⾔的⽬标程序。
2、编译程序是计算机系统中重要的系统软件!3、解释程序与编译程序的主要区别是解释程序在执⾏过程中不产⽣⽬标程序。
4、编译的各个阶段。
答:整个编译过程可以分为5个阶段:词法分析,语法分析,语义分析及中间代码⽣成,代码优化和⽬标代码⽣成。
5、编译程序的结构框图或步骤。
6、遍(趟):是对源程序或源程序的中间结果从头到尾扫描⼀遍,并作有关加⼯处理,⽣成新的中间结果或⽬标程序的过程。
■第2章1、符号串的基本运算。
2、简单的说⽂法由产⽣式组成;产⽣式中的符号分为两类:终结符号和⾮终结符号。
3、推导(最左、最右)、句型、句⼦、短语、句柄4、乔姆斯基层次中:L3 ? L2 ? L1 ? L0■第2章例题已知⽂法G[E]:E→T|E+T|E-TT→F|T*F|T/FF→(E)|i(1)该⽂法的开始符号是什么?(2)请给出该⽂法的终结符号集合VT和⾮终结符号集合VN。
(3)找出句型T+T*F+i的所有短语、直接(简单)短语、句柄。
■第3章1、词法分析程序的输出是单词符号序列。
2、DFA的三种表⽰形式——状态转移图、状态转换表和五元组表⽰(Q, ∑, f, S, Z );3、正规式向DFA的转换:(1)正规式——NFA;(转换原则见下页)(2)NFA——DFA;(3)DFA的最⼩化。
4、DFA向正规式的转换。
正则式向NFA转换的原则:例:构造与正则表达式R=ba(a|b)*等价的状态最少的DFA,并写出该DFA的五元组形式或状态转换表。
■第4章1、语法分析⽅法的各种分类;2、LL(1)分析⽅法。
提⽰:在此算法中注意First集和Follow集的求法。
并且⼀定要注意分析过程中步骤要完整。
(分析步骤见下页总结)例:⽂法:S?a|^|(T) T?T,S|S试判断该⽂法是否是LL(1)⽂法。
习题4:P100 4.3 4.7 4.9■LL(1)分析⽅法相关知识总结1、消除⽂法中的左递归或提取左因⼦;(1)简单直接左递归的消除A →βA’A →Aα| β→A’ →αA’| ε(2)将⽂法G:A→αβ|αγ提取左因⼦。
编译原理总复习

DFA和NFA
DFA M=K,,f,S,Z
K为状态的有穷非空集; 为有穷输入字母表; f是转换函数,是在K×Σ* →K上的映射; S∈K是唯一的一个初态; Z K是终止状态集; K为状态的有穷非空集; 为有穷输入字母表; f是转换函数,是在K×Σ* →2K上的映射; SK是初始状态集; Z K为终止状态集.
3. 4.
解释程序和一些软件工具 程序设计语言泛型
1.1 什么是编译程序
编译程序是现代计算机系统的基本组成部分。
1.1 什么是编译程序
编译程序是一个语言翻译程序。
高级语言程序 (源程序)
编译程序
机器(汇编种语言(源语言)书写的程序翻译 成另一种语言(目标语言)的等价程序。 编译程序把高级语言所写的源程序翻译成等价的 机器语言或汇编语言的目标程序。
符号串的头尾,固有头和固有尾 符号串的连接 符号串的方幂 符号串集合的乘积 符号串集合的方幂 符号串集合的闭包
符号串集合——句子的集合
主要目的:将语言形式化表示的基础
知识点二:文法的形式定义
规则的非空有穷集合,通常表示 成四元组 G={VN,VT, P, S } VN是规则中非终结符号的集合。
文法等价 若L(G1)=L(G2),则称文法G1和G2是等价的
知识点四: 文法的类型
通过对产生式施加不同的限制,Chomsky将文 法分为四种类型:
0型文法:对任一产生式α →β ,都有α ∈ (VN∪VT)* 且 至少含有一个非终结符, β ∈(VN∪VT)* 1型文法:对任一产生式α →β ,都有|β |≥|α |, 仅 仅 S→ε 除外 2型文法:对任一产生式α →β ,都有α ∈VN , β ∈(VN∪VT)* 3型文法:任一产生式α →β 的形式都为A→aB或A→a, 其中A∈VN ,B∈VN ,a∈VT *
编译原理全复习(完整版)

1》编译程序的框架图与功能块:(1)画出编译程序的总体结构,并简述各部分的主要功能:七个部分(2)编译程序的结构分为几个阶段,各阶段的任务是什么?答编译程序总框架(1)词法分析器,又称扫描器,输入源程序,进行词法分析,输出单词符号。
(2)语法分析器,简称分析器,对单词符号串进行语法分析(根据语法规则进行推导或规约),识别出各类语法单位,最终判断输入串是否构成语法上正确的“程序”。
(3)语义分析与中间代码产生器,按照语义规则对语法分析器归约出(或推导出)的语法单位进行语义分析并把它们翻译成一定形式的中间代码。
(4)优化器,对中间代码进行优化处理。
(5)目标代码生成器,把中间代码翻译成目标程序。
(6)表格管理,登记源程序的各类信息,编译各阶段的进展状况。
(7)出错管理,把错误信息报告给用户。
编译程序的结构分为五个阶段:(1)词法分析.任务是:输入源程序,对构成源程序的字符串进行扫描和分解,识别出一个个的单词(亦称单词符号或简称符号),如基本字,标识符,常熟,算符和界符。
(2)。
语法分析,任务是:在词法分析的基础上,根据语言的语法规则,把单词符号串分解成各类语法单位(语法范畴)。
(3)语义分析与中间代码产生。
任务:对语法分析所识别出的各类语法范畴,分析其含义,并进行初步翻译(产生中间代码)。
(4)优化。
任务在于对前段产生的中间代码进行加工变换,以期在最后阶段能产生出更为高效(省时间和空间)的目标代码。
(5)目标代码生成。
任务是:把中间代码(或优化出理之后)变换成特定机械上的低级语言代码。
2》.重要概念:a. 编译程序:是指能够把源语言程序转换成逻辑上等价的目标语言程序的一个程序。
b. 单词符号:是语言的基本组成成分,是人们理解和编写程序的基本要素,是语言中具有独立意义的最基本结构,它一般包括:基本字、标识符、常数、运算符和界符等c. 中间代码:是一种含义明确,便于处理的记号系统,它通常独立于具体的硬件。
编译原理总复习

信息记录在一个内情向量表中,这些信息包括:维数、首地 址、各维界差、各维上界、各维下界、数组元素类型、地址 不变量。
(1)基本概念
优化
(2)代码优化遵循的原则
等价原则、有效原则、合算原则
(3)优化分类
根据优化对象所涉及的程序范围划分为:局部优化、循环优化和全局 优化。 (4)常见的优化的几种方法
为E1´E2´op,其中E1´,E2´分别是E1和E2的后缀式。 ③若E是(E1)形式的表达式,则E的后缀式就是E1的后缀式。
(6)将以下语句翻译为四元式序列
①表达式(算术及布尔) ②赋值语句 ③IF语句 ④WHILE语句
(7)参数传递的几种方式
传地址、 传值、传名、得结果
返回
(1)符号表的基本组成、基本操作 组成:一张符号表的每一项入口包含:名字栏和信息栏 操作:查表、填表、访表、更新、删除
(7)LL(1)分析器的组成部分
输入缓冲区、分析栈、分析表、总控程序
(8)LL(1)分析的四种动作
成功、匹配、推导、报错
(9)LL(1)文法的判定条件
①文法不含左递归。
②文法中每一个非终结符A的各个产生式的候选首符集两两不相交。即,
若
A 1| 2| | n
则
FIR i) S FT IR ( j) S T ( i(j)
3型 2型 1型 0型
返回
(1)基本概念
状态等价、DFA的化简
(2)词法分析器的任务及其输出形式
任务:自左至右逐个字符地对源程序进行扫描,按语言的构词规则识别 出一个个单词,把作为字符串的源程序改造为单词符号串的中间程序。 输出形式:二元式 ( 单词种别, 单词符号的属性值)
《编译原理》总复习

17
<2> 符号表的组织
1. 符号表的条目与信息的存储(关键字+内容) 2. 作用域信息的保存(栈结构) 3. 线性表与散列表
<3> 声明语句的翻译
1. 定义与声明:类型定义与变量声明,过程定义与过程声明 2. 变量声明:符号表信息的填写 3. 过程声明: • 左值与右值 • 参数传递:参数传递的不同形式 • 名字的作用域:静态作用域与最近嵌套原则 • 声明中作用域信息的保存
12
<3> 自上而下分析
1. 分析方法:推导,从上到下构造分析树,是一种预测的、 试探的方法; 2. 对文法的要求:没有公共左因子和左递归; 3. 递归下降子程序方法:匹配终结符,展开非终结符(子 程序调用) 4. 预测分析表方法: • 工作方式与过程:PDA(DPDA)、格局与改变格局的 动作; • 预测分析表的构造:FIRST集合与FOLLOW集合, FIRST与FOLLOW的计算; • LL(1)文法及其判别:预测分析表中没有多重定义条 目(推论3.2)。
2. 移进-归约分析表:动作表+转移表; 3. LR文法与LR分析:LR(0)、SLR(1)、LALR(1)、LR(1)。
15
第四章 语法制导翻译生成中间代码
本章讨论程序设计语言的静态语义分析,并且在语法分析 的基础上生成中间代码,采用的基本方法是语法制导翻译。 与前两章词法分析和语法分析不同的是,词法分析和语法 分析的讨论侧重于理论,而本章则侧重于结合程序设计语言的 实际例子讨论语言结构的具体翻译方法和一些实用的技术。
西安电子科技大学软件工程研究所归纳总结所学内容锻炼提高抽象能力一引言二词法分析三语法分析四语法制导翻译生成中间代码学习不能走捷径付出多少劳动就有多少收获
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
习题2.10
有一NFA的状态转换矩阵下表,其中S为初态,D为终态
a S A A,B A b C,D c D C ε A,B.C B
B
C
A
B
D
A
C
A
1. 求出它的最小DFA 2. 用 正 规式描述 DFA 所 接受的语言
D
C
B
S
问题:根据DFA写出对应的正规式,通常的考虑和步骤是什么? 再重复一遍: 正规式、DFA是从两个不同的侧面表示一个集合 (即正规集)。所 以,根本的方法是把正规集作为桥梁,先分析清楚DFA识别出的 是一个什么集合,然后再设计此集合的正规式。反之亦然。
《编译原理》复习
西安电子科技大学 软件工程研究所
习题与试题
• 认真复习,重点是掌握基本概念。基本概念掌握了,相 当一部分试题的解就有了 • 习题与试题的目的区别:习题的目的是通过反复的练习 理解、掌握所学知识,会有不少繁、难、大量步骤的题; 试题的目的是考察对本课程综合掌握的情况,特点是短 时间内覆盖大量内容。太繁琐步骤或太难等需要耗费大 量时间的题是不可能出的 • 自己要会辨别什么是主要的什么是次要的,抓什么丢什 么。“基本概念要严谨(清楚),基本方法要灵活” • 总之一句话,学习方法的掌握是个人努力的结果,单纯 靠别人教是学不会的
如果是我复习
1. 词法分析 • 基本概念:正规式、正规集、有限自动机,词法分析 器的构造 • 常见计算题类型:已知集合求正规式、DFA;已知正规 式求DFA、集合;已知FA求正规式、集合;FA的确定化、 最小化。 2. 语法分析 • 基本概念:上下文无关文法、语言、下推自动机,LL 分析与LR分析; • 一些必要的定义、公式、算法的核心思想等; • 常见的计算题类型:(自己思考) • 基本解题方法与技巧等。 3. 语法制导翻译(略)(哪些最重要?)
,
三、计算题(3.3)
3.3(13分)已知一个NFA如图。 (a)(4 分 ) 用自然语言简要叙述该自动机所识别的语 言 的特点,列举两个它可识别的串。 (b)(3分)写出与该自动机等价的正规式r。 (c)(6分)用子集法构造识别r的最小DFA。
a,b 0 b 1 b
a,b 2
三、计算题(3.4)
第一章 引言
<1> 语言的翻译
不同的翻译形式:汇编、编译、转换(预编译)、逆向翻译
翻译方法:
源程序 输入数据 编译器 目标程序 目标程序 输出
源程序 输入数据
解释器
输出
19
<2> 编译器的基本组成
源程序 词法分析 语法分析 出 语义分析 中间代码生成 代码优化 目标代码生成 目标代码 错 处 理
习题 4.4
假定下述程序分别采用值调用,引用调用,复写- 恢复和换名 调用,请给出它们的打印结果。
program main(input output); procedure p(x,y,z); begin y:=y+1; z:=z+x end; begin a:=2; b:=3; p(a+b, a, a); print a
关于考试
• 题目类型:简答题(30分)、填空题(20分)、计算题(50分) • 内容分布 (大概 ) :概述与词法分析 (30分)、语法分析 (40分 )、 语法制导翻译与运行环境(30分) • 考试范围:1-4章讲过的内容 • 侧重考察:基本概念与基本方法的掌握
易犯的错误
1. 不认真审题(题目的要求理解错误:意思理解错、难题想 容易、容易题想难。关键问题是基本概念不清楚) 2. 所答非所问(例如:没有要求LL分析却将文法改为LL的) 3. 画蛇添足(例如:仅问有无冲突却将分析表先构造出来) 4. 偷工减料(例如:有若干问,仅回答部分或问题仅答一半)
22
<1> 记号、模式与单词
• 模式(pattern):规定单词识别的规则 • 记号( token ):按照某模式识别出的一类单词(记号种类 ) • 单词(lexeme):被识别出的字符串本身 • 词法分析器的输出:记号=记号种类+记号属性
<2> 记号的说明-模式的形式化描述
1. 正规式与正规集: • 正规式与正规集的定义(基本正规式、三个运算) • 正规式的等价(描述相同的集合) • 利用正规式的等价对正规式进行化简(正规式的代数性质) 2. 用正规式对模式进行形式化描述: • 如何用正规式描述程序设计语言中常见的记号,如标识 符、数字、运算符和分隔符等 23 • 正规式的简化形式以及辅助定义与规则
习题2.4
写出下述语言的正规式描述 (1) 由偶数个0和奇数个1构成的所有01串 (2) 所有不含子串011的01串 (3) 每个a后面至少紧随两个b的ab串 (4) C的形如/*…*/ 的注释。其中…代表不含*/的字符串 问题:拿到这类题该怎样思考,然后去解决?(特别是(1)) 思路:分析题意,从最简单的例子考虑,然后找出统一规律 步骤: 1. 最简单的符合要求的串:1、010(还有100或001) 2. 所有01均为偶数的串: A=((00|11)|(01|10)(00|11)*(10|01))* 3. 符合要求的所有串:A1A、A0A1A0A(为什么没有后两个?) 结果:A1A | A0A1A0A 思考:识别它的DFA又应该如何构造?
用自然语言给出下述正规式所描述的语言,并构造他们的最小DFA 10*1 (0|1)*011(0|1)*
问题:看得懂,但是不太会用自然语言较好的表达 说明:所谓用自然语言描述就是解释字符串的性质,一般情 况下是已经有了形式化描述。注意:这就是练习的目的。 解: 10*1:首尾是1中间有零或若干个0的01串。 (0|1)*011(0|1)* :至少含一个011的01串。 注意:绝对不允许用正规式形式表示,因为正规式已经给出
符 号 表 管 理
20
<3> 编译器的分析-综合模式
编译器 分析(前端) 源程序 语法/语义分析 综合(后端) 中间代码 代码生成/优化 目标代码
<4> 编译器的扫描遍数与编译器的编写
21
第二章 词法分析
词法分析器的作用: • 滤掉源程序中的无用成分; • 处理与具体操作系统或机器有关的输入; • 识别记号并交给语法分析器; • 调用符号表管理器和出错处理器进行相关处理。 构词规则与词法分析: 首先规定单词形成的规则,称为构词规则;然后根据 构词规则识别输入序列,称为词法分析。 主要内容: <1> 记号、模式与单词 <2> 记号的说明-模式的形式化描述(正规式与正规集) <3> 记号的识别-有限自动机 <4> 从正规式到词法分析器
习题3.7
设计一文法G,使得L(G)={ω|ω是不以0开始的正奇数} 问题:不知怎样着手做设计题,通常步骤是什么? (看到这样的问题我要疯掉了,都是一样的思路吗) 思路:首先根据集合的描述设计几个句子,然后从句子中找 出规律(或共性),把它们的性质用产生式表示出来。 解: 正规式: 个位:[13579] 个位以上:[0-9]* 最高位:[1-9] 三段连起来:[1-9][0-9]*[13579] 产生式: S→ACB|B A→1|2|3|4|5|6|7|8|9 B→1|3分)编译程序的基本组成有:词法分析、 、 、中 间代码生成、 、 、 和 。 2.3(1分)正规式r和s等价说明 相同。 2.4(2分)不含子串baa的所有a、b符号串的正规式是 。 2.9(4分) 已知文法G定义如下: S→eT|RT T→DR|ε R→dR|ε D→a|bd 则FIRST(S)= ,FIRST(D)= ,FIRST(T)= ,FIRST(R)= 。 2.2 语法分析、语义分析、代码优化、目标代码生成、 符号表管理和出错处理 2.3 r和s表示的正规集 2.4 a*(b|ba)* 2.9 FIRST(S)= {e,d,ε,a,b} ,FIRST(D)= {a,b} FIRST(T)= {ε,a,b} ,FIRST(R)= {d,ε} 。
构造SLR(1)分析表的方法:
a J I A K
1.可移进项直接从DFA上看: action[I,a]:=sj goto[I,A]:=k 2.可归约项分两步走:若在I状态中有[A→α.], 首先计算:FOLLOW(A), 然后填写:action[I,b]:=Ri 其中:b∈FOLLOW(A)且A→α是第i个产生式。
(a)(4分)求句型(T+F)*id 的短语、直接短语以及句柄; (b)(4分)根据语法制导翻译写出句子a*b+c*d的中间代码; (c)(3分)若a=3,b=5,c=7,d=8,请给出中间代码计算结果; (d)(4分)将文法G简化为:E→E*T|T,T→T+F|F,F→id。给出 它的识别活前缀的DFA。
习题2.10(2)的解
0 b,c 2 b,c a b a a,c 1
该DFA从初态到终态有三条路径:b|c|a(a|c)*b,而且是 这三条路径的至少一次重复,故正规式为:(b|c|a(a|c)*b)+
习题3.2
对所给文法:S→(L)|a L→L,S|S (3) 用自然语言描述该文法所产生的语言 问题:同样不理解“用自然语言表达” 思路:所谓用自然语言描述就是解释句子的性质,一般情况 下是已经有了形式化描述(CFG)。解题思路是先用所给 的产生式集合产生若干句子,然后分析句子的共性,从 中找出规律。根据这一思想再看习题解答。
警示
千万不要作弊!命运掌握在自己的手中!
4
实际试题举例
一、简答题
1.1(2分)有哪些方法可以去除文法的二义性。 1.2(2分)写出 -((a+b)*c)+d 的后缀式。 1.5(4分)试证明正规式(ab)*a与a(ba)*是等价的。 1.1 (1)改写文法 (2)规定文法符号的优先级和结合性 1.2 ab+c*@d+(或ab+c*-d+) 1.5 证明: 考虑L((ab)*a)中的任意一个串ababab...aba, 由串连接的结合性可得:a(ba)(ba)(b...a)(ba),它恰好 是L(a(ba)*), 即L((ab)*a)= L(a(ba)*)。 也可以用归纳法证明(提示:以ab重复0次、1次作为归纳 基础,假设ab重复n次成立,证明ab重复n+1次也成立)。