加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

perl – 如何从列表中删除可以在列表中其他较长行中找到的行?

发布时间:2020-12-15 21:48:00 所属栏目:大数据 来源:网络整理
导读:我有一个文件list.txt,像这样: catbeartreecatfishfishbear 我需要删除文档中其他地方已经完全找到的任何行,可以是重复行,也可以在另一行中找到.例如,“熊”和“熊”的行是相同的,因此删除其中一行; “猫”可以完全在“鲶鱼”中找到,因此“猫”被删除.输出
我有一个文件list.txt,像这样:
cat
bear
tree
catfish
fish
bear

我需要删除文档中其他地方已经完全找到的任何行,可以是重复行,也可以在另一行中找到.例如,“熊”和“熊”的行是相同的,因此删除其中一行; “猫”可以完全在“鲶鱼”中找到,因此“猫”被删除.输出看起来像这样:

catfish
tree
bear

如何删除所有重复行,包括在列表中较长行中找到的行?

到目前为止,我有这个:

#!/bin/bash
touch list.tmp
while read -r line
do
    found="$(grep -c $line list.tmp)"
    if [ "$found" -eq "1" ]
    then
        echo $line >> list.tmp
        echo $line" added"
    else
        echo "Not added."
fi
done < list.txt

解决方法

如果O(N ^ 2)不打扰你:
#!/usr/bin/env perl

use strict;
use warnings;
use List::MoreUtils qw{any};

my @words;
for my $word (
    sort {length $b <=> length $a}
    do {
        my %words;
        my @words = <>;
        chomp @words;
        @words{@words} = ();
        keys %words;
    }
)
{
    push @words,$word unless do {
        my $re = qr/Q$word/;
        any {m/$re/} @words;
    };
}

print "$_n" for @words;

如果你想要O(NlogN)你必须使用某种特里方法.例如,使用后缀树:

#!/usr/bin/env perl

use strict;
use warnings;
use Tree::Suffix;

my $tree = Tree::Suffix->new();

my @words;
for my $word (
    sort {length $b <=> length $a}
    do {
        my %words;
        my @words = <>;
        chomp @words;
        @words{@words} = ();
        keys %words;
    }
)
{
    unless ($tree->find($word)){
        push @words,$word;
        $tree->insert($word);
    };
}

print "$_n" for @words;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读