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

regex – 如何基于给定的正则表达式构造CFG

我试图弄清楚如何基于给定的正则表达式构造CFG(无上下文语法).
例如,a(ab)*(a | b)
我认为有一个算法可以通过,但它确实令人困惑.
这是我到目前为止所得到的:

S->aAB; 
    A->aAb|empty;
    B->a|b;

这看起来不错吗?
任何帮助,将不胜感激.

解决方法

将CFG分为三个部分,分别为a,(ab)*和(a | b).

对于(a | b),你有B – > a | b对.

(ab)*意思是ab,abab,ababab等字符串.所以A – > abA |空的将是正确的生产.

因此,完整的语法变为:

S -> aAB
A -> abA | empty
B -> a | b

注意:A – > aAb | empty会导出像ab,aabb,aaabbb等字符串,这不是regular language,也不可能代表regular expression.

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

相关推荐