- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第二章文法与语言
第二章 文法和形式语言 本章主要介绍形式语言理论中的一些最基本的概念和基础知识,它是学习以后各章节的基础。 2.1 符号和符号串 2.1.1 字母表与符号串 ① 字母表:元素的非空有穷集合,习惯上用大写字母表示。 ② 符号:字母表中元素。 ③ 符号串:符号的有穷序列。 ④ 空符号串:不含任何符号的符号串,记为ε。 ⑤ 符号串集合:字母表Σ上的符号串组成的集合。 2.2 文法和语言 语言是特定字母表上具有一定语法结构的符号串的集合。若用L表示语言,用Σ表示字母表,则 L∈Σ* 文法(Grammar)是定义或描述语言的语法结构的一组形式规则(即语法规则)。一个程序语言的文法的目的就是用适当条数的规则把该程序语言全部成分描述出来。 2、文法和字汇表 文法可以定义成一个四元组G[S]=(VN,VT,S,P)。 其中,VT:非空有限的终结符号集; VN:非空有限的非终结符号集; S:开始符号,是文法G规定的最终目标; P:产生式的集合。 V=VN∪VT称为文法G[S]的字汇表。 VN∩VT= ?,S?VN。 为了方便,表示文法时只列出产生式,而不以4元组显示地表示出来。 2.6 文法和语言的分类 0型文法与0型语言 1型文法与1型语言 2型文法与2型语言 3型文法与3型语言 0型文法 0型文法(无限制的文法)。其产生式具有以下形式: ?→? 其中,??V+,且至少含有一个非终结符;??V* 1型文法(上下文有关文法) 1型文法G的产生式具有以下形式: xUy→xuy 其中x,y?V*;U?VN; u?V+。 例如:1型文法G[S] =(VN,VT,P,S) 其中, VN={S,X,Y,Z} VT=(x,y,z) P={S→xSYZ?xYZ, xY→xy,yY→yy, yZ→yz ZY→YZ, zZ→zz} 2型文法(上下文无关文法) 在1型文法的产生式中上下文x和y用空符号串?代替,则有以下形式的产生式称为2型文法: U→u 其中,U?VN,u?V+。 例如:2型文法G[E] =(VN,VT,P,E) 其中, VN={E,T,F} VT={+,*,(,),i } P={E→E+T?T,T→T?F?F,F→(E) ?i } 3型文法 如果的产生式只含有下面的两种形式: U→a 或 U→aB 其中U,B?VN,a?VT*,则称该文法为右线性文法,如果文法的产生式只含有下面的两种形式: U→a或U→Ba 其中U,B?VN,a?VT* ,则称该文法为左线性文法 例如:右线性文法G[S]=(VN,VT,P,S) 其中, VN={S,A,B} VT={0, 1 } P={S→0?1?1A?0B,A→1A?0B,B→0?1?0B } The end. * * 2.1.2 符号串的运算 ① 符号串的长度:符号串中所包含的符号个数。设符号串为x,则其长度记为|x|。 例:空符号串长度为0,即|ε|=0。 ② 符号串的连接:设有符号串x和y,把y的所有符号相继写在x的符号串之后所得到的符号串即称为x和y的连接,记为xy. 例:εx = xε=x ③ 符号串的方幂:设x是符号串,则x的n次连接称为n次方幂,记为xn. 例: x0=ε ④ 符号串的前缀、后缀、子串 假设x是一个符号串,则有: 符号串x的前缀是指:从符号串x的尾部删除若干(含0个)符号后得到的符号串; 符号串x的后缀是指:从符号串x的头部删除若干(含0个)符号后得到的符号串; 符号串x的子串是指:删除了x前缀(或删除x的后缀或删除x的前缀和后缀)后得到的符号串; 对任意的符号串x,x的前缀、后缀都是x的子串,但x的子串不一定是x的前缀或后缀。 对任意的符号串x,x和ε都是符号串x的前缀、后缀,也是x的子串。 2.1.3 符号串集合的运算 ① 符号串集合的乘积:设A、B为符号串集合,则符号串集合的乘积表示为AB={xy|x∈A, y∈B},即A中的任意符号串和B中的任意符号串的连接所构成的集合。 因为有 xε=εx =x ,所以有 {ε}A={ε}A=A ② 符号串集合的方幂:即同一个符号串集合的乘积。 例:设A为符号串集合,则 A0={ε}, A1=A, A2=AA,…… ③ 符号串集合的闭包 设A为符号串集合,则A的闭包表示为A*,其定义为:A的若干次幂( 包括0次
文档评论(0)