免费注册 查看新帖 |

Chinaunix

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

如何匹配出现最长的子串? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-10 13:43 |只看该作者 |倒序浏览
请各位指教一下如何做?

如有字串:
aaabaaaabaaaaabaaaaaaaabaaaaaaaaaaaabaabaaa

我想匹配出最长的那串a,如何做?我的预期是取到aaaaaaaaaaaa。谢谢了。

[ 本帖最后由 lytton32 于 2008-12-10 14:01 编辑 ]

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
2 [报告]
发表于 2008-12-10 14:00 |只看该作者
文不对题嘛

论坛徽章:
0
3 [报告]
发表于 2008-12-10 14:34 |只看该作者
Do a global match with /g first
Extract from the result the longest match

  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;
  4. $_ = "aaabaaaabaaaaabaaaaaaaabaaaaaaaaaaaabaabaaa";
  5. my @match = /(a+)/g;
  6. my $max   = 0;
  7. foreach (@match) {
  8.     $max = $_ if ( length $_ > length $max );
  9. }
  10. print "Longest match is \[$max]\n";
复制代码

[ 本帖最后由 churchmice 于 2008-12-10 14:39 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2008-12-10 14:47 |只看该作者
或者用这个
参考自mastering regular expression pattern

  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;
  4. $_ = "aaabaaaabaaaaabaaaaaaaabaaaaaaaaaaaabaabaaa";
  5. my $pattern = qr/a+/;
  6. my $longest = undef;
  7. my $recordmatch = qr/(?{if ( not defined $longest or length $& > length $longest){$longest =$&;}})(?!)/;
  8. m/$pattern$recordmatch/;
  9. if (defined $longest){
  10.         print "Longest match = \[$longest]\n";
  11. }else {
  12.         print "No match\n";
  13. }
复制代码

论坛徽章:
0
5 [报告]
发表于 2008-12-10 18:02 |只看该作者
谢谢
收到了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP