免费注册 查看新帖 |

Chinaunix

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

利用正则去除子集 [复制链接]

论坛徽章:
1
羊年新春福章
日期:2015-04-28 20:40:58
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-09-15 15:07 |只看该作者 |倒序浏览
__DATA__
a b c
a b c d
c d e
c d e f g
f h
。。
。。

想输出
a b c d
c d e f g
f h
。。
。。

意思就是包含则去除。我想尽量用正则匹配的方法做到,还请大神们指点!感谢!

论坛徽章:
8
技术图书徽章
日期:2013-09-30 08:51:28技术图书徽章
日期:2013-12-11 09:26:39白羊座
日期:2013-12-27 15:27:13金牛座
日期:2014-01-06 09:13:05天蝎座
日期:2014-01-21 14:23:28酉鸡
日期:2014-05-09 16:51:12卯兔
日期:2014-08-11 16:49:1515-16赛季CBA联赛之八一
日期:2017-08-14 23:24:57
2 [报告]
发表于 2014-09-15 15:27 |只看该作者
  1. my @d = map {chomp;my $line = join " ",sort(split);$line}<DATA>;
  2. for my $f (@d) {
  3.         for my $s (@d) {
  4.                 next unless length $f lt length $s ;
  5.                 if ($s =~ /$f/) {
  6.                         $f = 0;
  7.                 }
  8.         }
  9. }
  10. my @a = grep {$_ ne 0} @d;
  11. print Dumper @a;

  12. __DATA__
  13. a b c
  14. a b c d
  15. c d e
  16. c d e f g
  17. f h
复制代码

论坛徽章:
1
羊年新春福章
日期:2015-04-28 20:40:58
3 [报告]
发表于 2014-09-15 15:53 |只看该作者
my @all;
while (<DATA>)
{
chomp;
push @all,$_;
}
@all = sort @all;
for (my $i=0;$i<=$#all;$i++)
{
         my $f=0;
         for (my $n=$i+1;$n<@all;$n++)
         {
                      if ($all[$n]=~/$all[$i]/)
                {
                $f++;
                }
                else{next;}
         }
         print "$all[$i]\n" if $f==0;
}
这是我自己写的,相比差太多了!谢谢!继续学习~回复 2# xiumu2280


   

论坛徽章:
8
技术图书徽章
日期:2013-09-30 08:51:28技术图书徽章
日期:2013-12-11 09:26:39白羊座
日期:2013-12-27 15:27:13金牛座
日期:2014-01-06 09:13:05天蝎座
日期:2014-01-21 14:23:28酉鸡
日期:2014-05-09 16:51:12卯兔
日期:2014-08-11 16:49:1515-16赛季CBA联赛之八一
日期:2017-08-14 23:24:57
4 [报告]
发表于 2014-09-15 16:00 |只看该作者
其实没差啊  只不过是思路不同 回复 3# 清泉一边


   

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
5 [报告]
发表于 2014-09-15 16:41 |只看该作者
LZ好象有点问题,
LZ 我想问一下。子集有没有包含
b d
a b d


__DATA__
a b c
b d
a b d
a b c d

论坛徽章:
1
羊年新春福章
日期:2015-04-28 20:40:58
6 [报告]
发表于 2014-09-15 16:52 |只看该作者
对的!当时没考虑这种情况!这种情况应该怎么写呢?
回复 5# substr函数


   

论坛徽章:
0
7 [报告]
发表于 2014-09-15 19:06 |只看该作者
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. my @list = map { split /\n/, $_ } <DATA>;
  5. for my $d (@list){
  6.   if( (grep { /^.+$d.*|^.*$d.+/ } @list) < 1){
  7.      print "$d\n";
  8.   }
  9. }

  10. __DATA__
  11. a b c
  12. a b c d
  13. c d e
  14. c d e f g
  15. f h
  16. f g
  17. a b f
  18. a b c k
  19. a b
复制代码

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
8 [报告]
发表于 2014-09-16 19:43 |只看该作者
回复 6# 清泉一边
它的真的很难。
a b c
f h
b d
fh c
a b d
b c d a
a c b d e
c d e
c d e f g
c e f
i j k
i j kl
s d
ss d

   

论坛徽章:
1
羊年新春福章
日期:2015-04-28 20:40:58
9 [报告]
发表于 2014-09-19 11:21 |只看该作者
最后还是hash解决的~回复 8# substr函数


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP