微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何从语法中获取正则表达式

如何解决如何从语法中获取正则表达式

下面的文法为正则文法,0和1为终结符,S、A、B为非终结符。

S → 0A | 1B | 0
A → 0A | 0S | 1B
B → 1B | 1 | 0

我试图将这个语法表达为正则表达式,但我不知道我的解决方案是否正确。

首先,

  • B = 1B + 1 + 0 = 1*(1+0)
  • A = 0A + 0S + 1B = 0A + 00A + 01B + 00 + 1B = (0+00)A + (01 + 1)B + 00 = (0+00)A + (01 + 1)1 *(1+0) + 00 = (0+00)*{(01 + 1)1*(1+0) + 00}

因此,

  • S = 0A + 1B + 0 = 0(0+00)*{(01 + 1)1*(1+0) + 00} + 1*(1+0) + 0

目前解决了相关问题,看起来这么长,没有复杂的案例,所以我觉得有一个错误的部分,但很难找到。如果我的解决方案有任何问题,请告诉我,我将不胜感激。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。