[软考考点解析]软件设计师--正规式与正规集

2. 方法

如果我们有两个字符a、b,那么有以下几种常用正规式写法。


正规式a,表示单一字符a,对应的正规集{a}。

正规式a|b,表示单一字符a或者b,对应有2个元素的正规集{a,b}。

正规式ab,表示由两个字符ab的元素,对应只有1个元素的正规集{ab}。

正规式ab(a|b),ab是确定的部分,然后再添加a或b,对应正规集{aba,abb}。

正规式a*,*表示任意个,对应正规集{Φ,a,aa,aaa,...}。

正规式(a|b)*,可以表示任意由a、b组成的串的集合,对应正规集{Φ,a,b,ab,aa,bb...}。

3. 刷题

题目:由a、b构造且仅包含偶数个a的串的集合,用正规式表示为()。

A: (a*a)*b*

B: (b*(ab*a)*)*

C: (a*(ba*)*b)*

D: (a|b)*(aa)*


解析:

对于A,如果第一个星号执行0次,第二个星号执行1次,第三个星号执行1次,结果为:ab,a不是偶数个,错误。

对于B,由于中间括号中两个aa必然成对出现,所以是偶数个a,正确!

对于C,第一个星号执行1次,第二、三个星号执行0次,第四个星号执行1次,结果为:ab,a不是偶数个,错误。

对于D,如果(a|b)执行为a,且第一个星号执行1次,第二个星号执行1次,结果为:aaa,a不是偶数个,错误。

上一篇:解决Django Mail from must equal authorized user', 'webmaster@localhost' 问题


下一篇:使用C#实现网站用户登录