码迷,mamicode.com
首页 > 其他好文 > 详细

上下文无关文法

时间:2014-11-17 17:11:47      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:http   ar   sp   strong   on   bs   ad   ef   as   

在计算机科学中,若一个形式文法 G = (N, Σ, P, S) 的产生式规则都取如下的形式:V -> w,则称之为上下文无关文法英语:context-free grammar,缩写为CFG),其中 V∈N ,w∈(N∪Σ)* 。上下文无关文法取名为“上下文无关”的原因就是因为字符 V 总可以被字串 w 自由替换,而无需考虑字符 V 出现的上下文。一个形式语言是上下文无关的,如果它是由上下文无关文法生成的(条目上下文无关语言)。

上下文无关文法重要的原因在于它们拥有足够强的表达力来表示大多数程序设计语言的语法;实际上,几乎所有程序设计语言都是通过上下文无关文法来定义的。另一方面,上下文无关文法又足够简单,使得我们可以构造有效的分析算法来检验一个给定字串是否是由某个上下文无关文法产生的。例子可以参见 LR 分析器和 LL 分析器。

BNF(巴克斯-诺尔范式)经常用来表达上下文无关文法。

形式定义

上下文无关文法 G 是 4-元组:

bubuko.com,布布扣 这里的

1. bubuko.com,布布扣 是“非终结”符号或变量的有限集合。它们表示在句子中不同类型的短语或子句。

2. bubuko.com,布布扣 是“终结符”的有限集合,无交集于 bubuko.com,布布扣,它们构成了句子的实际内容。

3. bubuko.com,布布扣 是开始变量,用来表示整个句子(或程序)。它必须是 bubuko.com,布布扣 的元素。

4. bubuko.com,布布扣 是从 bubuko.com,布布扣 到 bubuko.com,布布扣 的关系,使得 bubuko.com,布布扣

此外,bubuko.com,布布扣 是有限集合。bubuko.com,布布扣 的成员叫做文法的“规则”或“产生式”。星号表示Kleene星号运算。

补充定义 1

对于任何字符串 bubuko.com,布布扣,我们称 bubuko.com,布布扣 生成 bubuko.com,布布扣,写为 bubuko.com,布布扣,如果 bubuko.com,布布扣 使得 bubuko.com,布布扣 且 bubuko.com,布布扣。因此 bubuko.com,布布扣 是应用规则 bubuko.com,布布扣 于 bubuko.com,布布扣 的结果。

补充定义 2

对于任何 bubuko.com,布布扣(或 bubuko.com,布布扣 在某些教科书中),如果 bubuko.com,布布扣 使得 bubuko.com,布布扣

补充定义 3

文法 bubuko.com,布布扣 的语言是集合

bubuko.com,布布扣

补充定义 4

语言 bubuko.com,布布扣 被称为是上下文无关语言(CFL),如果存在一个 CFG bubuko.com,布布扣 使得 bubuko.com,布布扣

范式

每一个不生成空串的上下文无关文法都可以转化为等价的 Chomsky 范式或 Greibach 范式。这里两个文法等价的含义指它们生成相同的语言。

由于 Chomsky 范式在形式上非常简单,所以它在理论和实践上都有应用。比如,对每一个上下文无关语言,我们可以利用 Chomsky 范式构造一个多项式算法,用它来判断一个给定字串是否属于这个语言(CYK算法)。

上下文无关文法

标签:http   ar   sp   strong   on   bs   ad   ef   as   

原文地址:http://www.cnblogs.com/javaleon/p/4103811.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!