Your results can vary greatly depending on your data. Check out this code that gives you a pretty evenly distributed sample.
use Benchmark;
# Get 200 random 4-digit integers
my @array = (grep {/\d{4}/} map { 10000 * (sprintf "%0.4f", rand) } (1
+..400))[1..200];
print "N = " . @array . "\n\n"; # Be sure we have the right sample siz
+e
timethese(0, {
sorty => \&sorty,
space => \&spaceship,
comp => \&comp
});
sub sorty {
sort @array
}
sub comp {
sort {$a cmp $b} @array
}
sub spaceship {
sort {$a <=> $b} @array
}
PRINTS:
N = 200
Benchmark: running comp, sorty, space, each for at least 3 CPU seconds
+...
comp: 3 wallclock secs ( 3.15 usr + 0.01 sys = 3.16 CPU) @ 1064618.
+52/s (n=3368453)
sorty: 3 wallclock secs ( 3.11 usr + 0.00 sys = 3.11 CPU) @ 1096416
+.69/s (n=3415338)
space: 3 wallclock secs ( 3.11 usr + 0.00 sys = 3.11 CPU) @ 1064940
+.23/s (n=3314094)
Looks like a pretty even race to me!
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.