By using a hash as per the FAQ, the intersection/difference calculation will be order-independent. You will have to compare the resulting hash (called %count in the FAQ) against a given file's content to determine which file lacked the line in question. Note that the FAQ's code fails if either array has repeat entries.
Alternatively, you can use bit operations rather than simple incrementation to encode a little extra info. The FAQ code structure is more immediately obvious, but this may do more of what you want:
#!/usr/bin/perl
use strict;
use warnings;
my $master = shift;
my $completed = shift;
open my $mh, '<', $master or die "Open fail on $master: $!";
my @master_lines = <$mh>;
chomp @master_lines;
open my $ch, '<', $completed or die "Open fail on $completed: $!";
my @completed_lines = <$ch>;
chomp @completed_lines;
my %count;
for my $element (@master_lines) {
$count{$element}|=1;
}
for my $element (@completed_lines) {
$count{$element}|=2;
}
print "$master only:\n";
for my $element (@master_lines) {
next if $count{$element} & 2;
print "$element\n";
}
print "$completed only:\n";
for my $element (@completed_lines) {
next if $count{$element} & 1;
print "$element\n";
}
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.
|