编译原理ppt课件CHAPTER2(GrammarandLanguage).ppt
《编译原理ppt课件CHAPTER2(GrammarandLanguage).ppt》由会员分享,可在线阅读,更多相关《编译原理ppt课件CHAPTER2(GrammarandLanguage).ppt(61页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Chapter2Grammar and Language一教学目的一教学目的 掌握文法、语法树、推导、归约、句子、语言、规范推导与归 约、短语、简单短语、句柄、二义性定义,了解文法的分析过程、文法实用限制、语言分类等。二教学重点和难点二教学重点和难点重点掌握:1串和语言的概念。2文法和语言的定义。3文法和语言的分类。4分析树与句型。难点:1文法和语言的分类。2分析树与句型。2/17/20231Chapter2Grammar and Language 三教学内容三教学内容n串和语言(串和语言(Strings and Languages)n文法和语言的定义文法和语言的定义 (Definitions
2、 of Grammar and Language)n文法和语言的分类文法和语言的分类 (Classification of Grammar and Language)n分析树与句型分析树与句型 (Parse Tree and Sentential form)2/17/202322.1 2.1 串和语言串和语言n 字母表(字母表(alphabet):):n字母表是符号(symbols)的非空有穷集合,用表示n符号:可以相互区别的记号(元素)n不同的语言有不同的字母表n汉语汉字n英语26个英文字母2/17/202332.1 2.1 串和语言串和语言n符号串(符号串(String):):n符号串是由
3、字母表中的符号所组成的有穷序列n在语言理论中,符号串又称为:句子(句子(sentence)、字(字(word)n例如:=a,b a,b,aa,ab,aabba都是上的符号串n是任何上的符号串2/17/202342.1 2.1 串和语言串和语言n符号串的长度n符号串中包含符号的个数n符号串 s 的长度记为|s|n例,对于字母表a,b,c,aab 是其上的一个符号串,|aab|=3n注意:空符号串,|=02/17/202352.1 2.1 串和语言串和语言n符号串的前缀(prefix)、后缀(suffix)、子串(substring)n后缀:删去符号串 s 头部的零个或多于零个符号得到的符号串n例
4、如:nana是符号串banana的一个后缀n前缀:移走符号串 s 尾部的零个或多于零个符号得到的符号串n例如:b是符号串banana的一个前缀2/17/202362.1 2.1 串和语言串和语言n符号串的真(proper)前缀、真后缀和真子串非空n子串:从 s 中删去一个前缀和一个后缀得到的符号串n例如:ana是符号串banana的一个子串n*对于每个符号串s,s和两者都是符号串 s的前缀,后缀和子串2/17/202372.1 2.1 串和语言串和语言n 语言(语言(Language):):n某个字母表上的符号串的集合集合n例:汉语所有符合汉语语法的句子构成的集合 PASCAL语言所有合法的P
5、ASCAL程序构成的集合n注意:空集、和的不同2/17/202382.1 2.1 串和语言串和语言n符号串的运算:n连接(concatenation):符号串x、y的连接,是把 y 的符号写在 x 的符号之后得到的符号串 xyn如 x=ab,y=cd 则 xy=abcd n注:=n方幂(exponentiation):符号串自身连接n次得到的符号串nn 定义为 n个n1=,2=,注:0=2/17/202392.1 2.1 串和语言串和语言n语言的运算(operations on languages):n语言是符号串的集合,集合的运算有并、交、差等n并运算 等同于集合的并运算2/17/20231
6、02.1 2.1 串和语言串和语言n连接(乘积)n两个符号串集合 A 和 B 的乘积定义为:AB=xy|x A 且 y B n例如:集合A=ab,cde B=0,1 则 AB=ab1,ab0,cde0,cde1 nL=L=L nLLL=Ln L0=2/17/2023112.1 2.1 串和语言串和语言n*闭包(Kleene closure)nL*=L0L1L2L3 n+闭包(Positive closure)nL+=L1L2L3nL*=L+2/17/2023122.1 2.1 串和语言串和语言n注:后面通常是考虑字母表的*闭包和+闭包n例:=a,b *=,a,b,aa,ab,ba,bb,aaa
7、,aab,+=a,b,aa,ab,ba,bb,aaa,aab,2/17/2023132.1 2.1 串和语言串和语言n综合性的例子:P93 example 3.2n L=A,B,C,Z,a,b,c,zn D=0,1,9n把 L 和 D 两个字母表看作长度为1的符号串集合,即语言1.L D 2.LD 3.L4 4.L*5.L(L D)*6.D+2/17/2023142.2 2.2 文法和语言的定义文法和语言的定义n如何来描述一种语言?如何来描述一种语言?n如果语言是有穷的(只含有有穷多个句子),可以将句子逐一列出来表示n如果语言是无穷的,找出语言的有穷表示。2/17/2023152.2 2.2
8、文法和语言的定义文法和语言的定义n语言的有穷表示有两个途经:n生成方式(文法):语言中的每个句子可以用严格定义的规则来构造。n识别方式(自动机):用一个过程,当输入的一任意串属于语言时,该过程经有限次计算后就会停止并回答“是”,若不属于,要么能停止并回答“不是”,(要么永远继续下去。)n文法即是以生成方式描述语言的:语言中的每个句子可以用严格定义的规则来构造.2/17/2023162.2 2.2 文法和语言的定义文法和语言的定义n文法文法 G 定义为四元组(定义为四元组(VT,VN,S,P):):nVT:终结符(terminals)集,其中的元素一般用小写字母或数字表示(a,b,c0,1.),
9、代表语言中不可再语言中不可再分的基本符号分的基本符号,如汉语中的汉字、PASCAL语言中的基本字nVN:非终结符(nonterminals)集,其中的元素一般用大写字母表示(A,B,C),或者用尖括号括起,代表语法单位语法单位,如汉语中的语句、段落,PASCAL语言中的语句、表达式、子程序等2/17/2023172.2 2.2 文法和语言的定义文法和语言的定义nS 是一个特殊的非终结符号,称为开始符号(start symbol)nS 至少要在一条产生式中作为左部出现nP是一个产生式(production)的集合n产生式(重写规则、生成式),是形如或=的(,)有序对,且V+,V*其中 V=(VT
10、VN)n称为产生式的左部,不能为空n称为产生式的右部,可以为空(如:A )2/17/2023182.2 2.2 文法和语言的定义文法和语言的定义例1:文法 G=(VT,VN,S,P)VN=S VT=0,1 P=S0S1,S01 n可以只写出产生式,通过产生式可以得到文法的其它部分n左部相同的产生式可以写在一起,如:S 0S1|012/17/2023192.2 2.2 文法和语言的定义文法和语言的定义例2:文法 G=(VT,VN,S,P)VN=,VT=a,b,c,x,y,z,0,1,9P=a,z 0,9 S=2/17/2023202.2 2.2 文法和语言的定义文法和语言的定义n推导(推导(de
11、rivation)与归约()与归约(reduction):):n直接推导与直接归约n如果 A 是 G 的一条产生式,则称用代替A为一步直接推导直接推导,记为A=;称用A代替为一步直接归约直接归约,记为 0S1=00S11=000111,长度为3 记为:S 000111 S S2/17/2023222.2 2.2 文法和语言的定义文法和语言的定义n最左推导与最右推导n=是一步推导,(VTVN)*n最左推导(=lm)对 中的最左非终结符进行展开n最右推导(=rm)对 中的最右非终结符进行展开2/17/2023232.2 2.2 文法和语言的定义文法和语言的定义n例子:表达式文法 E E+T E T
12、 T T*F T F F (E)F a最左推导:E=lmT=lmT*F=lmF*F=lma*F=lma*a*最右推导又称为规范推导最右推导:E=rmT=rmT*F=rmT*a=rmF*a=rma*a2/17/2023242.2 2.2 文法和语言的定义文法和语言的定义n最右归约与最左归约n最左推导的逆过程是最右归约,即对最右边的可归约串进行归约 a*a=a*F=F*F=T*F=T=En最右推导的逆过程是最左归约,即对最左边的可归约串进行归约 a*a=F*a=T*a=T*F=T T=T*F=F*F=a*F=a*a 中,句型有:E、T、T*F、F*F、a*F、a*a句子是:a*a2/17/2023
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 原理 ppt 课件 CHAPTER2 GrammarandLanguage
限制150内