确定有限状态自动机

基础概念

 定义

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

  • 一个非空有限状态的集合 Q
  • 一个输入字母表 Σ(非空有限字符的集合)
  • 一个转移函数(单值映射) /delta: Q /times /Sigma /rarr Q (例如:/delta /left( q,/sigma /right) = p, /left( p,q /in Q, /sigma /in /Sigma /right)
  • 一个开始状态 s /in Q
  • 一个接受状态(终结状态)的集合 F /sube Q

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

非正式的语义

确定有限状态自动机一个字符接一个字符的读入一个字符串 w /in /Sigma ,并根据给定的转移函数一步一步的转移至下一个状态。在读完该字符串后,如果该自动机停在一个属于F的接受状态,那么它就接受该字符串,反之则拒绝该字符串。

 扩展转移函数

为了能够对DFA的命题进行证明,需要一个数学上的正式的语义定义。

为此我们定义一个扩展的转移函数 /delta^*: Q /times /Sigma^* /rarr Q

  • /delta^* /left( q,w /right) 是自动机从状态q顺序读入字符串w后达到的那个状态
  • 扩展转移函数递归的定义为:
    • /delta^* /left( q,/epsilon /right) = q
    • /delta^* /left( q,u/sigma /right) = /delta(/delta^*(q,u),/sigma), /forall u /in /Sigma^*, /sigma /in /Sigma

 正式的语义

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

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

利弊

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

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

其它

  1. 能被确定有限状态自动机识别的语言是正则语言
  2. 确定有限状态自动机是非确定有限状态自动机的一种极限形式。
  3. 确定有限状态自动机在计算能力上等价于非确定有限状态自动机。
  4. 没有接受状态列表并没有指定开始状态的确定有限状态机叫做转移系统半自动机

例子

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

/mathcal{A}状态图

确定有限状态自动机/mathcal{A} = /left( Q,/Sigma,/delta,s,F /right)

  • Q = {S1,S2}
  • Σ = {0,1}
  • s = S1
  • F = {S1}
  • δ 由下面的状态转移表定义:
 01
S1S2S1
S2S1S2
  • 对应的转移函数为:
    • δ(S1,0) = S2
    • δ(S1,1) = S1
    • δ(S2,0) = S1
    • δ(S2,1) = S2

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

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

封闭性及一些运算

封闭性

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

补运算

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

 交运算和并运算

有两个DFA,/mathcal{A}_1=(Q_1,/Sigma,/delta_1,s_1,F_1)/mathcal{A}_2=(Q_2,/Sigma,/delta_2,s_2,F_2) ,那么由这两个DFA创造出来的新的自动机定义为:/mathcal{B}= (Q_1 /times Q_2,/Sigma,/delta_/mathcal{B},(s_1,s_2),M) 。其中M /sube Q_1 /times Q_2/left( s_1 , s_2 /right)/mathcal{B} 的开始状态,/delta_/mathcal{B}/mathcal{B} 的转移函数,且作如下定义:/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) )

  1. M = F_1 /times F_2 时,由上述方法得到的/mathcal{B} 就是DFA/mathcal{A}_1/mathcal{A}_2 的交运算,记作:/mathcal{B} = /mathcal{A}_1 /cap /mathcal{A}_2 。也就是说对于读入的字符串w,当且仅当 /mathcal{A}_1/mathcal{A}_2 同时接受w的时候/mathcal{B} 接受w。
  2. M = Q_1 /times F_2 /bigcup F_1 /times Q_2 时,由上述方法得到的/mathcal{B} 就是DFA/mathcal{A}_1/mathcal{A}_2 的并运算,记作:/mathcal{B} = /mathcal{A}_1 /cup /mathcal{A}_2 。也就是说对于读入的字符串w,只要 /mathcal{A}_1/mathcal{A}_2 中至少有一个接受w,/mathcal{B} 就接受w。

交运算和并运算的复杂度都是 O(/left| Q_1 /right| /left| Q_2 /right| /left| /Sigma /right|)

同态和逆同态运算

一个同态函数 h: /Sigma^* /rarr /Gamma^* 可以递归的定义为:

  • ~h(/epsilon)=/epsilon
  • ~h(u/sigma)=h(u)h(/sigma)

于是则有 ~h(uv)=h(u)h(v) 。(以上所述中~/epsilon 为空字符,~u,v /in /Sigma^* , /sigma /in /Sigma

  1. /mathcal{L} /sube /Sigma^* : h(/mathcal{L}) := /{ h(w) ~| ~w /in /mathcal{L} /} :对于接受语言L的DFA,只要将其中代表~/delta(q,/sigma) 的边替换成一个序列~h(/sigma) 并在其中加入不属于原DFA状态的新状态,就产生了接受语言h(L)的DFA。
  2. /mathcal{L} /sube /Gamma^* : h^{-1}(/mathcal{L}) := /{ w ~| ~h(w) /in /mathcal{L} /} :定义一个~Q,/Sigma,s,F 都不变的新DFA,并定义新的转移函数为~/delta'(q,/sigma) := /delta^*(q,h(/sigma)) ,则~(Q,/Sigma,/delta',s,F) 就是逆同态运算产生的新DFA。

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

最小自动机

等价类自动机

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

~L 被称为Nerode关系,是Myhill-Nerode定理的基础。简单的来说就是对于任意~x,y,z /in /Sigma^* ,如果 xz /in L /Leftrightarrow yz /in L ,那么 x~Ly 。

唯一性

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

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

算法

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

  1. 如果 p /in F, ~q /notin F ,就给所有的状态对(p,q)和(q,p)打上标记
  2. 重复步骤3,直到所标记的状态对没有变化为止
  3. 对于未标记的状态对(p,q)和σ,如果 ~(/delta(p,/sigma),/delta(q,/sigma)) 被标记过了就把(p,q)也标记上
  4. 以上所有标记了的状态对的集合就是非等价关系N

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

  1. 把所有不能从开始状态达到的状态删除
  2. 通过上述标记算法计算非等价关系N
  3. 一步一步将不属于N的状态对中的两个状态合成一个状态

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

参见

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值