编译原理课程学习-程序设计语言及文法

本文介绍了编译原理中的基本概念,包括字母表、串、文法的定义以及文法的分类,如0型文法、1型文法、2型文法和3型文法。还探讨了推导、规约、句型、句子以及文法的二义性等关键点。此外,分析树作为推导的图形化表示也在文中进行了说明。
摘要由CSDN通过智能技术生成

编译原理-程序设计语言及文法

概念整理

//编译原理的课程复习,参考资料来源慕课哈工大编译原理课程

  • 字母表∑ :有穷符号集合

    • 乘积:在这里插入图片描述

    • n次幂:在这里插入图片描述

    • 正闭包:在这里插入图片描述

    • 克林闭包:在这里插入图片描述

    • ps:可以看出这正闭包和克林闭包的区别就在于时候有空串ε

  • :字母表中符号的一个有穷序列(类似于字母表中的元素的一个序列

    • 长度表示:|abc|= 3 | ε|=0
    • 连接运算:xy表示把y串附加到x串后面
    • 幂运算:字母表的幂运算
  • 文法:描述语言构成的规则

    • 形式化定义 在这里插入图片描述
      • VT:终结符集 (语言的基本符号)

      • VN:非终结符集(语法变量)在这里插入图片描述

      • P:产生式

      • S:开始符号

    • 符号约定
      在这里插入图片描述
  • 推导和规约:二者是一个互逆的过程

    • 推导的定义:用产生式的右部替代左部
    • 直接推导:一步得到
      在这里插入图片描述
  • 句型和句子

    • 都是在产生式的左部
    • 句型可以包括终结符和非终结符
    • 句子只可以是非终结符
  • 语言:句子的集合记作 L(G)
    -同样具有多种计算和字母表和串的类似

  • 文法的分类

    • 0型文法(无限制文法、短语结构文法)
      ∀α → β∈ P, α中至少包含1个非终结符
    • 1型文法 (上下文有关文法)
      ∀α → β∈ P, | α| ≤| β|
      *左侧的符号的长度不多于右部
      产生式的一般形式: α1Aα2 → α1βα2 ( β≠ε )
    • 2型文法 (上下文无关文法)
      ∀α → β∈ P, α ∈ VN α得是非终结符
      产生式的一般形式: A→β
    • 3型文法 (正则文法)
      右线性(Right Linear)文法: A→wB 或 A→w
      左线性(Left Linear) 文法: A→Bw 或 A→w
      在这里插入图片描述
  • 分析树:推导的图形化表示

    • 根节点的标号为文法开始符号
    • 内部结点表示对一个产生式A→β的应用, 该结点的标号是此产生式左
      部A 。该结点的子结点的标号从左到右构成了产生式的右部β
    • 叶结点的标号既可以是非终结符,也可以是终结符。从左到右排列叶
      节点得到的符号串称为是这棵树的产出( yield )或边缘(f rontier)
    • 短语: 给定一个句型,其分析树中的每一棵子树的边缘称为该句
      型的一个短语
  • 二义性:如果一个文法可以为某个句子生成多棵分析树,
    则称这个文法是二义性的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值