This is the way I've usually seen it done. I was curious, so I ran a benchmark against the two.
use Benchmark;
my @list;
for ( 0..9999 )
{
push @list, sprintf "%d", 100 * rand ;
}
timethese(
1000,
{
'keys_map' => sub { my @uniq = keys %{{ map {$_ => 1} @list }}
+; },
'grep_seen' => sub { my %seen; my @uniq = grep ! $seen{$_}+
++, @list; },
}
);
Yields the following output.
Benchmark: timing 1000 iterations of grep_seen, keys_map...
grep_seen: 13 wallclock secs (11.17 usr + 0.00 sys = 11.17 CPU) @ 89
+.52/s (n=1000)
keys_map: 30 wallclock secs (29.28 usr + 0.00 sys = 29.28 CPU) @ 34
+.15/s (n=1000)
-
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.
|