帕里克定理

来自testwiki
跳转到导航 跳转到搜索

Template:NoteTA理論計算機科學中,帕里克定理指出,对于上下文无关语言,如果只关心其中每个终止符号出现的次数,而不考虑它们的顺序,那么存在正则语言与其对应[1]。这个定理可用于确定具有给定数量终止符号的字符串是否能为上下文无关语法接受[2]。1961年罗希特·帕里克第一次证明了它[3],论文于1966年再次发表[4]

定义及形式化表述

Σ={a1,a2,,ak}为一个字母。定义单词的帕里克矢量p:Σ*k为函数[1]

p(w)=(|w|a1,|w|a2,,|w|ak),其中|w|ai表示词wai出现的次数。

一个子集k线性的,如果它形如

存在向量u0,,um,使得u0+u1,,um={u0+t1u1++tmumt1,,tm}

一个子集k半线性的,如果它为有限多线性子集的并。

帕里克定理的形式化表述如下。令L为上下文无关语言。令P(L)L单词的帕里克矢量集,即P(L)={p(w)wL}。则P(L)是半线性的。

两种语言可以等效互换,如果他们的帕里克矢量集相同。若S为任意半线性集,则对单词的帕里克矢量位于S中的语言,可等效于某些正则语言。因此,每一个上下文无关语言都可等效于某些正则语言。

重要性

帕里克定理表明,有些上下文无关语言可能只有歧义语法Template:Explain。这样的语言称为固有歧义语言。从形式文法的角度看,这意味着某些有歧义的上下文无关文法无法转换为明确的上下文无关文法。

参考文献

Template:Reflist