编译原理文法设计—每个a后面至少一个bab个数相等,ab个数不相等的所有串

Posted 之墨_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了编译原理文法设计—每个a后面至少一个bab个数相等,ab个数不相等的所有串相关的知识,希望对你有一定的参考价值。

编译原理【文法设计】—设计每个a后面至少一个b、ab个数相等,ab个数不相等的文法

为字母表 Σ = a , b Σ=\\a,b\\ Σ=a,b上的下列每个语言设计一个文法

(a) 每个a后面至少有一个b的所有串

  • 首先,每个a后面至少有一个b的正规式怎么写呢?
  • 每个a都需要至少跟一个b,那么可以用ab表示
  • 那么这个串的前面可以有若干个a或者若干个b或者他们的任意组合,那么保证有了ab以后,在它的前面或者后面都添加若干个a或b
  • 则正规式为:(ab|b)*,这样得到了上述语言的正规式
  • 那么文法怎么写呢?直观的看,该正规式可以推到ab之后跟任意ab或者b的串,可以推到空串,也可以推到b开头后续跟任意ab或b的串
  • 则用一个文法符号S表示,可以推到如下文法
    • S → a b S S → b S S → ϵ S→abS\\\\ S→bS\\\\S→\\epsilon SabSSbSSϵ
    • 这个文法就满足
      • 可以推到ab开头之后跟任意ab或者b的串
      • 可以推到b开头后续跟任意abb的串
      • 可以推到空串

(b)a和b个数相等的所有串

  • S → a B ∣ b A ∣ ϵ A → a S ∣ b A A B → b S ∣ a B B S→aB|bA|\\epsilon\\\\A→aS|bAA\\\\B→bS|aBB SaBbAϵAaSbAABbSaBB
  • 上述文法怎么得到的呢?
  • 如下:
    (c)a和b个数不相等的所有串

以上是关于编译原理文法设计—每个a后面至少一个bab个数相等,ab个数不相等的所有串的主要内容,如果未能解决你的问题,请参考以下文章

编译原理 文法题目

编译原理之理解文法和语言

编译原理:考虑文法G[S]

编译原理之文法和语言总结与梳理

编译原理-LL1文法详细讲解

北航编译原理总结 C文法