当前位置: 代码网 > it编程>编程语言>正则表达式 > 正则文法与正则表达式的相互转化问题(编译原理)

正则文法与正则表达式的相互转化问题(编译原理)

2024年05月15日 正则表达式 我要评论
前言在词法分析过程中,如果将每类单词都看作一种语言,则大多数单词词法可以用正则文法来描述。 除了正则文法外,正则表达式也可以相应的用来描述单词,正则文法和正则表达式的能力相同,且可以互相转化。正则表达

前言

在词法分析过程中,如果将每类单词都看作一种语言,则大多数单词词法可以用正则文法来描述。 除了正则文法外,正则表达式也可以相应的用来描述单词,正则文法和正则表达式的能力相同,且可以互相转化。正则表达式比正则文法更直观,有时首选正则表达式来表示正则语言。

一、正则文法

1.定义

正则文法在这篇文章()中有所讲解,在此处再稍微讲述一遍:

  • 正则文法g = (v,t,p,s)中,对∀α —> β∈p,α β均具有形式a —> w或a —> wb(a —> w或a —> bw),其中a,b∈v,w∈t+。
  • 正则文法描述t上的正则语言。

2.例子

例子:词法分析中标识符的文法:

二、正则表达式

1.定义

定义:设∑是一个字母表,则∑上的正则表达式及其所表示的正则语言可递归地定义如下:

⑴ ø是∑上的一个正则表达式,它表示空集;

⑵ ε是∑上的一个正则表达式,它表示语言{ε};

⑶ 对于∀a(a∈∑),a是∑上的一个正则表达式,它表示的正则语言是{a};

⑷ 假设r和s都是∑上的正则表达式,它们表示的语言分别为l®和l(s),则:

( r )也是∑上的正则表达式,它表示的语言为l( r );
(r|s)也是∑上的正则表达式,它表示的语言为l( r )∪l(s);(并操作)
(r•s)也是∑上的正则表达式,它表示的语言为l( r )l(s);(连接操作)
(r*)也是∑上的正则表达式,它表示的语言为(l( r ))*;(克林闭包操作)

⑸ 使用上述规则构造的表达式是∑上的正则表达式。

2.例子

例子:词法分析中标识符的正则表达式表达:

在这里插入图片描述

三、转换规则

1.正则文法转换为正则表达式

具体转换步骤为:

1.根据正则文法g构造正则表达式联立方程组。

假设正则文法g是右线性的,其每个产生式的右部只含有一个终结符,则有如下方程式构造规则:

2.解联立方程组,求等价的正则表达式r。

用代入消元法逐个消去方程组中除开始符号s外的其他变量,最后即可得到关于开始符号s的解。

代入消元规则如下:

求得结果。如果最后得到的关于s的方程式为如下形式,s=α1|α2|…|αh则将方程式右边所有其中仍然含有语法变量的αi(1≤i≤n)删除,得到的结果就是与g等价的正则表达式。如果任意的αi(1≤i≤n)均含有语法变量,则ø就是与g等价的正则表达式。

2.正则表达式转换为正则文法

给定正则表达式r,按如下方法构造正则定义式,并逐步将其转换成正则文法。

引入开始符号s,从如下正则定义式开始:

s—>r

按如下规则将s—>r分解为新的正则定义式,在分解过程中根据需要引入新的语法变量。

在这里插入图片描述

四、转换例子

1.正则文法转换为正则表达式

在这里插入图片描述

过程:

在这里插入图片描述

2.正则表达式转换为正则文法

例1.标识符定义的转换:

(1).引入 s
(2).s→ (|)*
(3).分解为
s→ a
a→(|)a|ε

例2.(a|b)*a(a|b)(a|b)

转换成正则文法:
(1).s->aa|ab
(2).a->ba|bb
(3).b->ca
(4).c->ca|cb|ε

总结

正则表达式与正则文法等价:
对任意一个正则文法,存在一个定义同一语言的正则表达式;
对任意一个正则表达式,存在一个定义同一语言的正则文法。

到此这篇关于编译原理-正则文法与正则表达式的相互转化的文章就介绍到这了,更多相关正则文法转正则表达式内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

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

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com