【问题标题】:Converting a regular expression to a DFA将正则表达式转换为 DFA
【发布时间】:2015-07-15 09:41:27
【问题描述】:

我一直在尝试转换正则表达式

首先使用 Thompson 构造的非确定性有限自动机 (NFA),给出:

,看起来是正确的。

然后我使用子集构造从 NFA 创建 DFA,如下所示。

但这对我来说看起来不正确,例如根据我构建的 DFA,0 后跟 0 是无效的。我想知道如何在原始正则表达式中对 epsilon 进行建模,因为我只是将其视为普通 epsilon。

【问题讨论】:

  • 这个属于cs.stackexchange.com
  • 您的正则表达式缺少括号?
  • @Bergi 是的。图片显示了正确的正则表达式

标签: regex compiler-construction dfa computation-theory nfa


【解决方案1】:

一个匹配已经 - 因此你的图表中的状态 B 对于一个 dfa 必须已经是一个接受状态(只需将其标记为接受不会修复它!)。我无法重构你的想法,但你应该以类似的方式结束

A --0--> (B)
A --1-->  C
B --0--> (B)
B --1-->  C
C --0--> (B)
C --1-->  C

如果你从另一边开始思考,正则表达式(0|)(0|1)*0 可以通过删除第一部分(0|) 来简化。可以这样做是因为(0|1) 匹配(0|) 将匹配的所有内容(以及更多)。 你也可以在你的 nfa 图表中看到它。

S0->S1->S2->S5 === S7->S7->S8->S11
S0->S3->S4->S5 === epsilon

也许这可以帮助你把想法引向正确的方向..

【讨论】:

    猜你喜欢
    • 2017-10-04
    • 2021-07-10
    • 2019-04-08
    • 1970-01-01
    • 2013-10-28
    • 2015-12-21
    • 2017-02-09
    • 2018-04-16
    • 2011-10-02
    相关资源
    最近更新 更多