免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: cjog
打印 上一主题 下一主题

这是一个正则语言吗 [复制链接]

论坛徽章:
0
21 [报告]
发表于 2008-11-13 14:12 |只看该作者
原帖由 fineamy 于 2008-11-13 11:14 发表
设 r1 = (aa)*
    r2 = (bb)*
    r3 = (abab)*
    r4 = (baba)*
于是
   r = ((r1)*(r2)*(r3)*(r4)*)*a

((r1)*(r2)*(r3)*(r4)*)*是所有双数个数a,b形成的串,最后补一个a


abb?

论坛徽章:
0
22 [报告]
发表于 2008-11-13 14:21 |只看该作者

按照cjaizss 的DFA



这是个ε-NFA,可以看到这几个路径形成的串均是可接受串。
Dεa              a
DAεaa          (aa)*aaa
DAεbb          (aa)*abb
DABεb          (aa)*a(bb)*bb
DABCεab      (aa)*a(bb)*b(aa)*aab
DABCDεa      (aa)*a(bb)*b(aa)*a(bb)*ba
DCεab           (bb)*bab
DCBεb          (bb)*b(aa)*ab
DCBAεbb       (bb)*b(aa)*a(bb)*bbb
DCBAεaa       (bb)*b(aa)*a(bb)*baa
DCBADεa      (bb)*b(aa)*a(bb)*b(aa)*aa

上面加起来就是这个DFA所识别的所有串

[ 本帖最后由 fineamy 于 2008-11-13 14:36 编辑 ]

论坛徽章:
0
23 [报告]
发表于 2008-11-13 14:42 |只看该作者

搞了这么大半天

r1              (r12r13)*a
r2          (r12r13)*(aa)*aaa
r3          (r12r13)*(aa)*abb
r4          (r12r13)*(aa)*a(bb)*bb
r5      (r12r13)*(aa)*a(bb)*b(aa)*aab
r6     (r12r13)*(aa)*a(bb)*b(aa)*a(bb)*ba
r7           (r12r13)*(bb)*bab
r8         (r12r13)*(bb)*b(aa)*ab
r9       (r12r13)*(bb)*b(aa)*a(bb)*bbb
r10      (r12r13)*bb)*b(aa)*a(bb)*baa
r11      (r12r13)*(bb)*b(aa)*a(bb)*b(aa)*aa

r12   ((aa)*a(bb)*b(aa)*a(bb)*b)*
r13   ((bb)*b(aa)*a(bb)*b(aa)*a)*

最终结果:
r = r1 + r2 + r3 + r4 + r5 + r6 + r7 + r8 + r9 + r10 + r11

[ 本帖最后由 fineamy 于 2008-11-13 17:34 编辑 ]

论坛徽章:
0
24 [报告]
发表于 2008-11-13 14:47 |只看该作者

回复 #21 baohuaihuai 的帖子

应该这样

r = ((r1)*(r2)*(r3)*(r4)*)*a((r1)*(r2)*(r3)*(r4)*)*

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
25 [报告]
发表于 2008-11-13 15:29 |只看该作者
恩,确实有严格的数学证明:regex,dfa,3-type language三者等价

[ 本帖最后由 cjaizss 于 2008-11-13 15:31 编辑 ]

论坛徽章:
0
26 [报告]
发表于 2008-11-13 22:41 |只看该作者

根据正则式,

当然可以写出来.
S->D
D->a
D->aA
D->bC
A->aa
A->bb
A->aD
A->bB
B->b
B->bA
B->aC
C->ab
C->aB
C->bD

实际上可以去掉
A->aa
A->bb
C->ab

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
27 [报告]
发表于 2008-11-13 22:50 |只看该作者
S->D
D->a
D->aA
D->bC
A->aD
A->bB
B->b
B->bA
B->aC
C->aB
C->bD
不可去,这样无法生成aaa

[ 本帖最后由 cjaizss 于 2008-11-13 22:52 编辑 ]

论坛徽章:
0
28 [报告]
发表于 2008-11-14 11:38 |只看该作者

回复 #27 cjaizss 的帖子

的确。
否则aaa,babbb,abaab将无法生成。

论坛徽章:
0
29 [报告]
发表于 2008-11-14 15:18 |只看该作者
我是新人,哈哈~

论坛徽章:
0
30 [报告]
发表于 2008-12-04 21:44 |只看该作者
眼花缭乱啊,正则表达式,DFA,
对了,龙书上面的一些正则表达式的题目也是好难啊,
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP