zoukankan      html  css  js  c++  java
  • 上下文无关文法

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

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

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

    形式定义

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

    G = (V\,, Sigma\,, R\,, S\,) 这里的

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

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

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

    4. R\, 是从 V\, 到 (VcupSigma)^{*} 的关系,使得 exist\, win (VcupSigma)^{*}: (S,w)in R

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

    补充定义 1

    对于任何字符串 u, vin (VcupSigma)^{*},我们称 u\, 生成 v\,,写为 uRightarrow v\,,如果 exists (alpha, eta)in R, u_{1}, u_{2}in (VcupSigma)^{*} 使得 u\,=u_{1}alpha u_{2} 且 v\,=u_{1}eta u_{2}。因此 v 是应用规则 (alpha, eta) 于 u 的结果。

    补充定义 2

    对于任何 u, vin (VcupSigma)^{*}, ustackrel{*}{Rightarrow} v(或 uRightarrowRightarrow v\, 在某些教科书中),如果 exists u_{1}, u_{2}, cdots u_{k}in (VcupSigma)^{*}, kgeq 0 使得 uRightarrow u_{1}Rightarrow u_{2}cdotsRightarrow u_{k}Rightarrow v

    补充定义 3

    文法 G = (V\,, Sigma\,, R\,, S\,) 的语言是集合

    L(G) = { winSigma^{*} : Sstackrel{*}{Rightarrow} w}

    补充定义 4

    语言 L\, 被称为是上下文无关语言(CFL),如果存在一个 CFG G\, 使得 L\,=\,L(G)

    范式

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

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

  • 相关阅读:
    分类在使用runtime做方法交换时
    打包自己Framework中含有第三方库的解决方案分CocoaPods与手动导入两种方式
    iOS 百分比圆环曲线swift4.0实现
    最新swift4.0 图片进行尺寸大小及体积压缩
    swift 密码由6-16数字和字母组合组成
    Android 7.0 之后相机/文件读写等权限获取方式改变,导致开启相机闪退
    Android Manifest 中 uses-feature 和 uses-permission的作用 关系和区别
    Android studio 3.1.3真机调试报错,no target device found
    如何用Java实现条件编译
    Missing android.support.FILE_PROVIDER_PATHS meta-data 报错原因分析
  • 原文地址:https://www.cnblogs.com/javaleon/p/4103811.html
Copyright © 2011-2022 走看看