[系列][编译原理]子集构造

子集构造是用于描述从一个给定的NFA来构造DFA的算法,代号M

 

首先计算某个NFA,代号M初始状态的ɛ-闭包,得到的结果就是M的初始状态。对于这个集合以及之后的每个集合,计算a字符之上的转换如下所示:

 

假设有状态的S集合字母表中的字符a,计算集合S'_a = {t|对于S中的一些s,在a上有从st的转换}。接着计算S'_a,它是S'_a的闭包。这就定义了子集构造中这些构造的新状态和一个新的转换S --a-->S'_a,继续这个过程直到不再产生新的状态或者转换。当接受这些构造的状态时,按照包含了M的接受状态的方式作出记号。这就是DFA的M,它并不包括ɛ-转换,这是因为每个状态都被构造成了一个ɛ-闭包。它至多包括了一个来自字母a上的状态转换,这又是因为每个新状态都由从单个字符a上的一个状态的转换构造为来自M的所有可接受到的状态。

转载于:https://www.cnblogs.com/cwblaze/archive/2010/01/31/1660374.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值