- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
北航 计算理论 第一章 文法与语言
计算理论
第三章 文法与语言
上下文无关语言
上下文无关文法定义:
G(V, T, P, S), P中的产生式形如:
A . A∈V,(VT)*.
例:
上下文无关文法G = ( V, T, P, S), 其中:
V={S},
T={a, b},
P={S aSb, Se}
上下文无关文法
识别:对给定的字符串是否能由文法的开始符和产生式推导出。
例:上例中的文法G,是否能识别字符串aaaebbb.
语法树
二义性
E I
E E + E
E E * E
E (E)
I a
a + a * a
E T | E + T
T F | T* F
F I | (E)
I a
有些可手动消除;无自动消除算法
有些甚至是不可消除的。
上下文无关文法
乔姆斯基范式
如果一个上下文无关文法中产生式形如:
A BC 或 A a ,
其中aT,A,B,CV,且B,C不允许是文法的开始符,允许有空产生式S (S是文法的开始符),则称该文法为乔姆斯基范式。
上下文无关文法
定理:
任一上下文无关文法都可等价转换为乔 姆斯基范式形式。
范式是二叉树形式,对于任意给定的串,将非终极符为树枝,终极符为树叶,则该串可以认为是树,根据树的理论,可以将任何树转换为二叉树。
上下文无关文法
证明:
替换开始符S。
增加一个新开始符S’和新产生式S’ S。
消除空产生式A 。
对所有A的出现产生式形如R A,增加产生式R 。
上下文无关文法
若有R A,增加R ,重复前一动作。上下文无关文法
消除单元产生式A B。
对所有B的出现产生式形如B ,增加产生式 A。
替换:对A u1 u2 …un,n3。
替换为A u1A1,A1 u2 …un,n3。
对A1 u2 …un,继续前一动作。
上下文无关文法
上下文无关语言
上下文无关文法G(V,T,P,S)生成的语言:
L(G) = {ω|ω∈T*且S +ω}
上下文无关语言的识别
对文法G(V,T,P,S),任给串ω∈T*,S +ω成立否。
上下文无关文法
相关定义:ω=x1x2…xn
ωij :ω的子串ωij = xi…xi+j-1 ,ji,jn,i表示子串的起始位置,j表示串的长度。
如: ω11=x1 ,ω21=x2,…,ωi1=xi
…
ω1n=x1x2…xi…xi+j-1…xn=ω
上下文无关文法
Vij: Vij={A|A * ωij},该集合中的任何一个非终极符均可以推导出ωij。
如:V11={A|A + ω11}={A|(A x1)∈P}
…
Vj1={A|(A Xj)∈P}
…
Vn1={A|(A Xn)∈P}
上下文无关文法
识别算法:对字符串ω=x1x2…xn
若n=1,判断S x1是否在该文法的P中;
若n ≥2,判断(SBC)P,且BC+ ω;
即存在k(k≥1,k≤n-1),有:
B + ω1k,C + ω(k+1)(n-k)
求Vij ={A|(A BC)∈P,且B∈Vik,C∈V(i+k)(j-k)},其中k0,kj;简记为Vij={ Vik V(i+k)(j-k)}。
判断S∈V1n,是则说明ω能被文法G识别。
上下文无关文法
三角形法求Vij :
V11 V21 … Vi1 … … Vn1
V12 V22 … Vi2 … … V(n-1)2
… … … … … …
V1j V2j … Vij … V(n-i+1)j
… … … … …
V1n
for i :=1 to n do
Vi1 := { A| (A Xi)∈P, Xi∈T};
for j :=2 to n do
for i :=1 to n-j+1 do
Vij :=Φ;
for k :=1 to j-1 do
Vij :=Vij∪{A| (ABC)∈P, B∈Vik,
您可能关注的文档
- 北京市东城区2017届高三(上)期末生物试卷(解析版).doc
- 北京市2016年中考数学试题(word解析版).doc
- 北京市东城区2017届高三5月综合练习(二模)理综试题 WORD版含答案.doc
- 北京市各区中考二模试题分类汇编:记叙文阅读.doc
- 北京市昌平区2017届高三期末质量抽测政治试题 Word版含答案.doc
- 北京市丰台区2017届高三历史上学期期末考试试题.doc
- 北京市西城区2015-2016学年八年级上学期期末考试语文试卷.doc
- 北京市石景山区普通高中校2014年11.doc
- 北京市海淀区2017届高三上学期期末考试数学理试题(全Word版,含答案).doc
- 北京的山 六.docx
原创力文档


文档评论(0)