免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1525 | 回复: 4
打印 上一主题 下一主题

[函数] 请教一个有关正则表达式的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-22 22:22 |只看该作者 |倒序浏览
编写一个简单的支持正则表达式的字符串匹配函数,简单的正则表达式如下:
    字符              含义
     $                区配一个字符$
     _                区配任意一个字符
     *                若一个字符后紧跟*,则匹配0个或多个此字符
函数原型定义如下,参数regexp是待匹配的正则字符串,text是原始字符串,如果text中包含正则串,函数返回1,否则0
    int match(const char * regexp,const char *text)
例如:regexp:c*    text:cccccc返回1
     regexp:a_*d  text:abck返回1
     regexp:A*    text:bbcd返回0

请哪位高手先把思路写一下,再给出函数,万分感谢!!!!!!

论坛徽章:
0
2 [报告]
发表于 2008-09-22 22:57 |只看该作者
先解析regexp本身,然后分段匹配。
就想到这么点。

如果是负载的话,估计要用到编译原理中的若干理论。

论坛徽章:
0
3 [报告]
发表于 2008-09-23 00:11 |只看该作者
谢谢,能否给出一个具体的函数?

论坛徽章:
0
4 [报告]
发表于 2008-09-23 09:07 |只看该作者
就这个函数的本身的功能而言,完全不能算是正则的匹配。

而只是一个是否包含(Contains)的概念。

返回值只有1/0只是判断有没有,而这3个字符的意义(几乎)全是匹配通用的东西的,完全只是个范围,特别是最后一个“*”的通配符,不管怎么样,只要前面满足,这个“*”完全就是可以当作没有看到,返回的都是1。

也许是看了上面几个EG比较简单发现的,可能复杂点的会有点用。

只是个人认为哈。

论坛徽章:
0
5 [报告]
发表于 2008-09-23 15:02 |只看该作者
这个MS是今年BAIDU的笔试题,思想是用自动机实现,画一下状态转移图就了解该怎么编了,更牛的有用递归实现的,相对于自动机,代码要简单不少,但思想可能不太好理解
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP