确定有限状态自动机

✍ dations ◷ 2025-06-15 04:22:18 #确定有限状态自动机

在计算理论中,确定有限状态自动机或确定有限自动机(英语:deterministic finite automaton, DFA)是一个能实现状态转移的自动机。对于一个给定的属于该自动机的状态和一个属于该自动机字母表 Σ {displaystyle Sigma } 的字符,它都能根据事先给定的转移函数转移到下一个状态(这个状态可以是先前那个状态)。

确定有限状态自动机 A {displaystyle {mathcal {A}}} 是由

所组成的5-元组。因此一个DFA可以写成这样的形式: A = ( Q , Σ , δ , s , F ) {displaystyle {mathcal {A}}=left(Q,Sigma ,delta ,s,Fright)}

确定有限状态自动机从起始状态开始,一个字符接一个字符地读入一个字符串 w Σ {displaystyle win Sigma ^{*}} (这里的 {displaystyle {}^{*}} 指示Kleene星号算子。),并根据给定的转移函数一步一步地转移至下一个状态。在读完该字符串后,如果该自动机停在一个属于F的接受状态,那么它就接受该字符串,反之则拒绝该字符串。

为了在保证严谨的前提下,方便地叙述关于DFA的内容,我们定义如下扩展的转移函数:

对于一个确定有限状态自动机 A = ( Q , Σ , δ , s , F ) {displaystyle {mathcal {A}}=left(Q,Sigma ,delta ,s,Fright)} ,如果 δ ( s , w ) F {displaystyle delta ^{*}left(s,wright)in F} ,我们就说该自动机接受字符串w,反之则表明该自动机拒绝字符串w。

被一个确定有限自动机接受的语言(或者叫“被识别的语言”)定义为: L ( A ) = { w Σ | A   {displaystyle {mathcal {L}}({mathcal {A}})={win Sigma ^{*}|{mathcal {A}}~} 接受字符串   w } {displaystyle ~w}} ,也就是由所有被接受的字符串组成的集合。

除了数学上的严谨表述,通常为了讨论方便,也使用状态图直观地表示DFA。不难发现,对于一个给定的DFA,存在唯一一个对应的有向图(但是严格意义上一个有向图不能确定出唯一一个DFA)。有向图的每个结点对应一个状态,每条有向边对应一种转移。习惯上将结点画成两个圈表示接受状态,一个圈表示拒绝状态。用一条没有起点的边指向起始状态。

除了在表述上方便以外,在研究某些问题(如“给定的DFA的语言是否为无穷集合”)时,状态图也提供了有效的解法。

DFA是一种实际的计算模型,因为有平凡的线性时间、恒定空间的在线算法模拟在输入流上的DFA。给定两个DFA有有效算法找到识别它们所识别语言的并集、交集和补集的DFA。还有有效算法确定一个DFA是否接受任何给定字符串,一个DFA是否接受所有字符串,两个DFA是否识别同样的语言,和对特定正则语言找到状态数目最小的DFA(最小DFA)。

在另一方面,DFA在可识别的语言上有严格的限制—很多简单的语言,包括需要多于恒定空间来解决的任何问题,不能被DFA识别。经典的DFA不能识别的简单语言的例子是括号语言,就是由正确配对的括号组成的语言,比如 (()())。由形如anbn的字符串组成的语言,就是有限数目个a,随后是相等数目个b。可以证明没有DFA有足够状态来识别这种语言(通俗地说,因为需要至少2n个状态,而n是不恒定的)。

下面是一个确定有限状态自动机的例子。

确定有限状态自动机 A = ( Q , Σ , δ , s , F ) {displaystyle {mathcal {A}}=left(Q,Sigma ,delta ,s,Fright)}

状态 S 1 {displaystyle S_{1}} 表示在输入的字符串中有偶数个0,而 S 2 {displaystyle S_{2}} 表示有奇数个0。在输入中1不改变自动机的状态。当读完输入的字符串的时候,状态将显示输入的字符串是否包含偶数个0。

A {displaystyle {mathcal {A}}} 能识别的语言是 L ( A ) = { w | # 0 ( w ) 0   ( m o d   2 ) } {displaystyle {mathcal {L}}({mathcal {A}})={w|#_{0}(w)equiv 0~(mod~2)}} 。用正则表达式表示为: ( 1 ( 01 0 ) ) {displaystyle (1^{*}(01^{*}0)^{*})^{*}}

确定有限状态自动机的交,并,差,补,连接,替换,同态,逆同态等运算是封闭的,也就是说确定有限状态自动机通过这些运算产生的新的自动机也是确定有限状态自动机。

A = ( Q , Σ , δ , s , F ) {displaystyle {mathcal {A}}=(Q,Sigma ,delta ,s,F)} 是一个DFA,那么由补运算产生的新DFA定义为: A ¯ = ( Q , Σ , δ , s , Q F ) {displaystyle {bar {mathcal {A}}}=(Q,Sigma ,delta ,s,Q-F)} 。显然只要将 A {displaystyle {mathcal {A}}} 中接受的状态设为不接受的状态,同时把不接受的状态设为接受的状态就得到 A ¯ {displaystyle {bar {mathcal {A}}}} 。补运算的复杂度是: O ( | Q | ) {displaystyle O(left|Qright|)}

有两个DFA, A 1 = ( Q 1 , Σ , δ 1 , s 1 , F 1 ) {displaystyle {mathcal {A}}_{1}=(Q_{1},Sigma ,delta _{1},s_{1},F_{1})} A 2 = ( Q 2 , Σ , δ 2 , s 2 , F 2 ) {displaystyle {mathcal {A}}_{2}=(Q_{2},Sigma ,delta _{2},s_{2},F_{2})} ,那么由这两个DFA创造出来的新的自动机定义为: B = ( Q 1 × Q 2 , Σ , δ B , ( s 1 , s 2 ) , M ) {displaystyle {mathcal {B}}=(Q_{1}times Q_{2},Sigma ,delta _{mathcal {B}},(s_{1},s_{2}),M)} 。其中 M Q 1 × Q 2 {displaystyle Msubseteq Q_{1}times Q_{2}} ( s 1 , s 2 ) {displaystyle left(s_{1},s_{2}right)} B {displaystyle {mathcal {B}}} 的开始状态, δ B {displaystyle delta _{mathcal {B}}} B {displaystyle {mathcal {B}}} 的转移函数,且作如下定义: q 1 Q 1 ,   q 2 Q 2 ,   σ Σ : δ B ( ( q 1 , q 2 ) , σ ) = ( δ 1 ( q 1 , σ ) , δ 2 ( q 2 , σ ) ) {displaystyle forall q_{1}in Q_{1},~q_{2}in Q_{2},~sigma in Sigma :delta _{mathcal {B}}((q_{1},q_{2}),sigma )=(delta _{1}(q_{1},sigma ),delta _{2}(q_{2},sigma ))}

交运算和并运算的复杂度都是 O ( | Q 1 | | Q 2 | | Σ | ) {displaystyle O(left|Q_{1}right|left|Q_{2}right|left|Sigma right|)}

一个同态函数 h : Σ Γ {displaystyle h:Sigma ^{*}rightarrow Gamma ^{*}} 可以递归的定义为:

于是则有   h ( u v ) = h ( u ) h ( v ) {displaystyle ~h(uv)=h(u)h(v)} 。(以上所述中   ϵ {displaystyle ~epsilon } 为空字符,   u , v Σ , σ Σ {displaystyle ~u,vin Sigma ^{*},sigma in Sigma }

此外替换运算和逆同态运算的方法近似。

对于一个正则语言,接受该语言的等价类自动机是一个   ( Q , Σ , δ , s , F ) {displaystyle ~(Q,Sigma ,delta ,s,F)} 的5-元组。其定义如下:

~L被称为Nerode关系,是Myhill-Nerode定理的基础。简单的来说就是对于任意   x , y , z Σ {displaystyle ~x,y,zin Sigma ^{*}} ,如果 x z L y z L {displaystyle xzin LLeftrightarrow yzin L} ,那么x~Ly。

对于任意给定的确定有限状态自动机都能找到一个与之计算能力等价的最小确定有限状态自动机,简称最小自动机。该最小自动机中状态的数量等于能识别相同语言的等价类自动机中等价关系的数量,我们可以称最小自动机和等价类自动机“实际上”是相等的,也就是同构。非正式的说法是:对于最小自动机上的任意状态都可以通过一个同构函数变换成等价类自动机上的一个状态。

能识别一个正则语言的等价类自动机是唯一的,因此能识别该语言的最小自动机也是唯一的。

定义一个非等价关系: N := { ( p , q )   |   p , q Q , w Σ : δ ( p , w ) F δ ( q , w ) F } {displaystyle N:={(p,q)~|~p,qin Q,exists win Sigma ^{*}:delta ^{*}(p,w)in Fleftrightarrow delta ^{*}(q,w)notin F}} ,如下步骤可以得到这个集合N:

以下是由一个任意DFA转换到一个最小DFA的步骤:

这样就得到了接受相同语言的最小自动机。复杂度为 O ( | Q | 2 | Σ | ) {displaystyle O(left|Qright|^{2}left|Sigma right|)}

相关

  • 汉萨同盟汉萨同盟(拉丁语:Hansa、Hansa Teutonica或Liga Hanseatica,英语:Hanseatic League,又译汉撒同盟和汉莎同盟),12-13世纪中欧的神圣罗马帝国与条顿骑士团诸城市之间形成的商业、政治
  • 阿尤恩阿尤恩(法语:Laâyoune;西班牙语:El Aaiún;阿拉伯语:العيون‎ al-ʿuyūn;哈桑尼亚阿拉伯语: Laʕyūn ;柏柏尔语:ⵍⵄⵢⵓⵏ,中文含意为“泉水”),或称阿雍,是位于西撒哈拉地区
  • 韩式活章鱼 (신낙지)活章鱼(韩语:산낙지;英语:San-nakji)是朝鲜半岛的一种特殊传统料理,为用长腕小章鱼制作的脍菜(生食)。长腕小章鱼是在韩国被称为nakji的一种小型章鱼物种,由于其尺寸较巨型章鱼较小,有
  • 不信者不信者,或异教徒(英语:Infidel,字面意“不信者”)为基督教或伊斯兰教对无宗教或异教人士的称呼。在一神教世界通常为骂人词汇。不过某些伊斯兰教学者认为伊斯兰教中引用“异教徒
  • 御巫桃也御巫桃也,日本漫画家、插画家。代表作是目前在《Comic ZERO-SUM》(一迅社)连载、2013年4月至6月播出同名电视动画的《黑色嘉年华》。全由一迅社发行。
  • 塔希冈塔希冈(不丹语:བཀྲ་ཤིས་སྒང་།,英语:Trashigang或者Tashigang),也译为扎西冈、扎西岗,是不丹王国东部地区的最大城市,也是塔希冈宗的首府。位于不丹的最东边,平均海拔106
  • 续水浒传《续水浒传》,又名《征四寇》,接《水浒》原书七十回,共有五十回写起。作者托名罗贯中,也有可能来自《水浒》原书的节选。后和简本水浒传(前传)、三国演义合刻成《英雄谱》。近代
  • 2009年中国大陆矿难列表本条目旨在列举发生在2009年中国大陆的较重大矿难。据中国大陆官方统计,2009年中国大陆煤矿矿难共造成2631人死亡。 其中,2009年上半年中国大陆共发生各类事故186775起,死亡36370人。其中煤矿发生749起,死亡1175人。
  • 塞尔维亚饮食塞尔维亚饮食(塞尔维亚语:српска кухиња / srpska kuhinja)十分独特,融合了巴尔干饮食(特别是前南斯拉夫地区)、地中海饮食(特别是希腊)、土耳其饮食、中欧饮食(特别是奥地利饮食和匈牙利饮食)的特征。塞尔维亚饮食包含了来自前南斯拉夫各地的元素。奥斯曼帝国的统治使得塞尔维亚饮食受到了东方的影响,一些最传统的塞尔维亚饮食和土耳其及希腊有着相同的渊源。而奥匈帝国的统治也丰富了塞尔维亚饮食,特别是在甜点方面。现在塞尔维亚侨民将塞尔维亚饮食普及至世界各地。大多数塞尔维亚人饮食都是比较简单,
  • 1978年3月24日月食1978年3月24日月食为一次在协调世界时1978年3月24日出现的月全食。该次月食半影食分为2.505、全影食分为1.457。偏食维持了110分,全食维持46分。这次月食的食分是12.22,偏食维持了110分,全食维持46分。