正则语言

正则语言又称是满足下述相互等价的一组条件的一类形式语言

例子

  • 所有的有限语言都是正则的。
  • 字母表{a, b}上包含偶数个a的所有字串构成的语言是正则的。
  • 字母表{a, b}上取若干个a后紧跟若干个b形式的所有字串构成的语言是正则的。

定義

在字母表集合Σ上的正規語言定義如下:

  • 空集合Ø是正規語言
  • 只包含一個空字串的語言{ε}是正規語言
  • 對所有,{a}是正規語言
  • A, B是正規語言,則(kleene星号)都是正規語言
  • 除此之外都不是正規語言

如果一個語言不是正規語言,它需要一個記憶體至少是Ω(log log n)的自動機才能辨認。換句話說,DSPACE(o(log log n))等于所有正規語言的集合。實際上,大部份的非正規語言需要至少O(log n)的空間。

封闭性质

这里语言的运算参见条目形式语言

  • 正则语言的交、并、差、补运算得到的语言仍然是正则语言;
  • 两个正则语言连接(把第一个语言的所有字串同第二个语言的所有字串连接起来)后得到的语言仍然是正则语言;
  • 正则语言闭包运算后得到的语言仍然是正则语言;
  • 正则语言的每个字串转置后得到的语言仍然是正则语言;
  • 正则语言被任意语言的字符串商(左商或右商)后得到的语言仍然是正则语言。
  • 正则语言字符串代换后得到的语言仍然是正则语言。
  • 与正则语言字符串同态或逆同态的语言仍然是正则语言。

纯代数定义

正则语言也可以以纯粹代数的方式来定义。

Σ是一个有穷的字母表,Σ*是Σ上的自由幺半群,Σ*构成了Σ上的所有字串。令M为一个有限幺半群,映射f : Σ* -> M为一个幺半群同态,集合SM的一个子集,于是S的逆同态象f -1(S)是正规的。每一个正规语言都可以依这种方式来定义。

另外一种定义方式借助于一个等价关系。

L为Σ*的任意子集,定义如下的Σ*上的等价关系~ (叫做“语法关系”): u ~ v,即对Σ*中所有的的字串wuwL中当且仅当vwL中。于是对正规语言有下面的结论:语言L是正规的当且仅当关系~的等价类的数量是有限的(其证明在条目语法幺半群中)。在此情况下,等价类的数量就是接受语言L的最小确定有限状态自动机的状态数。

相关条目

引用

  • Michael Sipser. . PWS Publishing. 1997. ISBN 978-0-534-94728-6. Chapter 1: Regular Languages, pp.31–90. Subsection "Decidable Problems Concerning Regular Languages" of section 4.1: Decidable Languages, pp.152–155.

    外部链接

    This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.