形式语言与自动机7 ch4.1_第1页
形式语言与自动机7 ch4.1_第2页
形式语言与自动机7 ch4.1_第3页
形式语言与自动机7 ch4.1_第4页
形式语言与自动机7 ch4.1_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

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

文档简介

1、1College of Computer Science & Technology, BUPT 第四章第四章 上下文无关文法与下推自动机上下文无关文法与下推自动机 推导树和文法的二义性推导树和文法的二义性 上下文无关文法的变换上下文无关文法的变换 Chomsky范式范式 Greibach范式范式 下推自动机下推自动机 上下文无关语言的性质上下文无关语言的性质 2College of Computer Science & Technology, BUPT 本章要点本章要点 上下文无关文法(即上下文无关文法(即2型文法):型文法): 产生式形如产生式形如 A, A, )* 所描述的语言称为上下文无

2、关语言。所描述的语言称为上下文无关语言。 用途:用途: 可定义程序设计语言、进行语法分析、简化语言可定义程序设计语言、进行语法分析、简化语言 翻译翻译 2型文法对应的识别器型文法对应的识别器下推自动机下推自动机 PDA(Push Down Automata)由输入带、有限由输入带、有限 控制器和下推栈构成(书控制器和下推栈构成(书P152 图)图) 3College of Computer Science & Technology, BUPT 回顾:回顾:在第一讲中介绍过如下内容在第一讲中介绍过如下内容 设设 T= 0, 1 , L = 0n1n n 1 , 如如 0011, 000111,

3、01 L, 而而10, 1001 , , 010 L . 如下是一个可接受该语言的上下文无关文法如下是一个可接受该语言的上下文无关文法 S 01 S 0S1 但没有任何有限自动机能够接受语言但没有任何有限自动机能够接受语言L. 4College of Computer Science & Technology, BUPT 归约与推导的概念: 推理字符串是否属于文法所定义的语言推理字符串是否属于文法所定义的语言 一种是自下而上的方法,称为一种是自下而上的方法,称为递归推理递归推理(recursive inference),),递归推理的过程习称为递归推理的过程习称为归约归约; 一种是自上而下的方

4、法,称为一种是自上而下的方法,称为推导推导(derivation). 归约过程归约过程 将产生式的右部(将产生式的右部(body)替换为产生式替换为产生式 的左部(的左部( head ). 推导过程推导过程 将产生式的左部(将产生式的左部( head )替换为产生替换为产生 式的右部(式的右部( body ). 4.1 推导树和二义性 5College of Computer Science & Technology, BUPT 归约与推导 归约过程归约过程举例举例 对于对于CFG Gexp = (E,O, (, ), , v, d , P , E ) ,P 为为 (1)E EOE (2) E

5、 (E) (3) E v (4) E d (5) O (6) O 递归推理出字符串递归推理出字符串 v (vd) 的一个归约过程为的一个归约过程为 v (vd) (4) v (vE) (6) vO(vE) (3) vO(EE) (5) vO(EOE) (1) vO(E) (2) vOE (3) EOE (1) E 6College of Computer Science & Technology, BUPT 归约与推导 推导过程推导过程举例举例 对于对于CFG Gexp = (E,O, (, ), , v, d , P , E ) ,P 为为 (1)E EOE (2) E (E) (3) E

6、v (4) E d (5) O (6) O 从开始符号到字符串从开始符号到字符串 v (vd) 的一个推导过程为的一个推导过程为 v (vd) (4) v (vE) (6) E (E) (3) (1) v (EOE) (5) (3) EOE (1) EE E (2) v (E) v (EE) 7College of Computer Science & Technology, BUPT 归约与推导 E EOE E (E) E v E d O O 最左推导最左推导(leftmost derivations) 若推导过程的每一步总是替换出现在最左边的非终结符,若推导过程的每一步总是替换出现在最左边

7、的非终结符, 则这样的推导称为则这样的推导称为最左推导最左推导. 为方便,最左推导关系用为方便,最左推导关系用 表示,其传递闭包用表示,其传递闭包用表示表示. 如对于文法如对于文法Gexp ,下面是关于下面是关于 v (vd) 的一个最左推导的一个最左推导: lm lm v (vd)v (vE) v (EOE) EOEE v (E) vOEv E v (vOE) lm lm lm lm lm lm lm lm 8College of Computer Science & Technology, BUPT 归约与推导 E EOE E (E) E v E d O O 最右推导最右推导(rightm

8、ost derivations) 若若推导推导过程的每一步总是替换出现在最右边的非终结符,过程的每一步总是替换出现在最右边的非终结符, 则这样的推导称为则这样的推导称为最右推导最右推导. 为方便,最右推导关系用为方便,最右推导关系用 表示,其传递闭包用表示,其传递闭包用表示表示. 如对于文法如对于文法Gexp ,下面是关于下面是关于 v (vd) 的一个最右推导的一个最右推导: rm rm v (vd)E (vd) EO(Ed) EOEE EO(EOd) EO(E)EO(EOE) EO(vd) rm rm rm rm rm rm rm rm 9College of Computer Scien

9、ce & Technology, BUPT 推导树推导树 用图的方法表示一个句型的推导,这种图称为推导用图的方法表示一个句型的推导,这种图称为推导 树(也称语法树或语法分析树)。有助于理解语法树(也称语法树或语法分析树)。有助于理解语法 结构的层次。结构的层次。 定义方法:定义方法: n文法的起始符为根,树的枝结点标记是非终结符,文法的起始符为根,树的枝结点标记是非终结符, 叶结点标记为终结符或叶结点标记为终结符或 。 n若枝结点有直接子孙若枝结点有直接子孙x1, x2, xk,则文法中有生成则文法中有生成 式式Ax1 x2xk 10College of Computer Science &

10、Technology, BUPT 推导树举例 例:例:(书(书P124 例例1) 文法文法SS+S | S*S |(S)| a , 对句子对句子 (a*a+a) 可有推导树可有推导树 a aa a S S ( S )( S ) S + SS + S S * SS * Sa a a aa a S S ( S )( S ) S * SS * S S + SS + S a a 即:推导树是对文法G中一个特定句子形式特定句子形式的派生过程所做的一种自然描述。 11College of Computer Science & Technology, BUPT 边缘 叶子叶子从左向右组成的字符串称为推导树的

11、边缘。从左向右组成的字符串称为推导树的边缘。 如图如图 x1 y1 y2 x3 xm xm+1 xn-1 y3 y4 y5是树的边缘是树的边缘 y1y1y2y2 S S A BA B x1 Xx1 X2 2 . x . xm m . . x xm+1 m+1 . Xn . Xn y3y3 y4y4y5y5 12College of Computer Science & Technology, BUPT (1) E EOE (2) E (E) (3) E v (4) E d (5) O (6) O 归约过程自下而上构造了一棵树归约过程自下而上构造了一棵树 如对于文法如对于文法Gexp ,关于关于

12、 v (vd) 的一个归约过程可以认为是构造了如下一棵树的一个归约过程可以认为是构造了如下一棵树: v (vd) (4) v (vE) (6) vO(vE) (3) vO(EE) (5) vO(EOE) (1) vO(E) (2) vOE (3) EOE (1) E EE OE E O E E d v () v 13College of Computer Science & Technology, BUPT (1) E EOE (2) E (E) (3) E v (4) E d (5) O (6) O 推导过程自上而下构造了一棵树推导过程自上而下构造了一棵树 如对于文法如对于文法Gexp ,关

13、于关于 v (vd) 的一个推导过程可以认为是构造了如下一棵树的一个推导过程可以认为是构造了如下一棵树: E d v v OEE E() EEO v (vd) (4) v (vE) (6) E (E) (3) (1) v (EOE) (5) (3) EOE (1) EE E (2) v (E) v (EE) 14College of Computer Science & Technology, BUPT 归约、推导与分析树之间关系 三者之间的关系三者之间的关系 设设 CFG G = (V, T, P , S ). 以下命题是相互等价的:以下命题是相互等价的: (1) 字符串字符串 w T* 可

14、以归约(递归推理)到非终结符可以归约(递归推理)到非终结符A; (2) A w; (3) A w; (4) A w; (5) 存在一棵根结点为存在一棵根结点为 A 的分析树,其边缘为的分析树,其边缘为 w. lm rm 15College of Computer Science & Technology, BUPT 定理定理: 设设2型文法型文法G=(N,T,P,S),),如果存在如果存在S=+ , 当且仅当文法当且仅当文法G中有一棵边缘为中有一棵边缘为的推导树。的推导树。 证明:证明: 需证明对任意枝结点需证明对任意枝结点BN,有有B=* 当且仅当存在当且仅当存在 边缘为边缘为的的B树(根为

15、树(根为B的树)的树) 子树概念:子树概念: 一棵派生树的子树,是树中的某个顶点连同它的全部一棵派生树的子树,是树中的某个顶点连同它的全部 后裔,以及连接这些后裔的边。后裔,以及连接这些后裔的边。 归约、推导与分析树之间关系 16College of Computer Science & Technology, BUPT 证明步骤:证明步骤: 1. 证当证当是是B树边缘时,有树边缘时,有B =* 设设B树边缘为树边缘为,对树中枝结点数目对树中枝结点数目m作归纳证明。作归纳证明。 2. 设有设有B = * ,证明存在一棵边缘为证明存在一棵边缘为的的B树。树。 对对推导步数推导步数作归纳作归纳 1

16、7College of Computer Science & Technology, BUPT 1. 证当证当是是B树边缘时,有树边缘时,有B =* 设设B树边缘为树边缘为,对树中枝结点数目对树中枝结点数目m作归纳证明。作归纳证明。 w A X1X2 X3 w1w2w3 A 基础基础 m为为 1. 分析树一定如分析树一定如 右图所示,必定有产生右图所示,必定有产生 式式A w. 因此,因此, A w. 归纳归纳 m大于大于 1 的分析树一定的分析树一定 如右图所示,必定有产如右图所示,必定有产 生式生式 A X1X2Xk . 存在存在 w1,w2,wk,wi 是是Xi子树子树 的边缘(的边缘(

17、1 i k),),且且 w = w1w2wk, 由归纳由归纳 假设,假设, Xi wi(1 i k). 在此基础上易证得在此基础上易证得A w. 18College of Computer Science & Technology, BUPT 2. 设有设有B = * ,证明存在一棵边缘为证明存在一棵边缘为的的B树。树。 对对推导步数推导步数作归纳作归纳 基础基础 步数为步数为 1. 一定有产生式一定有产生式 A w . w 可以归约到可以归约到 A. 归纳归纳 设步数大于设步数大于 1,第一步使用了产生式,第一步使用了产生式A X1X2Xk . 该推导如该推导如 A X1X2Xk w . 可

18、以将可以将 w 分成分成 w = w1w2wk,其中其中 (a) 若若 Xi 为终结符,则为终结符,则 wi = Xi. (b) 若若 Xi 为非终结符,则为非终结符,则 Xi wi. 由归纳假设,由归纳假设, wi 可以归约到 可以归约到 Xi . 这样,这样,wi 或者为或者为Xi,或者可以归约到或者可以归约到 Xi ,使用产生使用产生 式式A X1X2Xk ,得出得出w 可以归约到可以归约到 A. 19College of Computer Science & Technology, BUPT 定义定义: 2型文法是二义的型文法是二义的,当且仅当对于句子当且仅当对于句子L(G),存在两棵不存在两棵不 同的具有边缘为同的具有边缘为的推导树。的推导树。 (即:如果文法是二义的即:如果文法是二义的, 那么它所产生的某个句子必然能从那么它所产生的某个句子必然能从 不同的最左不同的最左(右右)推导推出推导推出)。 例例: (书书P124 例例1) 句子句子(a*a+a)有二棵不同的推导树有二棵不同的推导树. (相当于一个先算乘法相当于一个先算乘法,一一 个先算加法个先算加法.) 注意注意: 可有二个文法可有二个文法,一个有二义一个有二义

温馨提示

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

最新文档

评论

0/150

提交评论