Beefy Boxes and Bandwidth Generously Provided by pair Networks
P is for Practical
 
PerlMonks  

Re^6: Advanced Bubble Sort

by AnomalousMonk (Archbishop)
on Oct 17, 2016 at 07:31 UTC ( [id://1174125]=note: print w/replies, xml ) Need Help??


in reply to Re^5: Advanced Bubble Sort
in thread Advanced Bubble Sort

FWIW, here's my latest take on the problem. I also have some doubt about what a "version string" is in this context, but like you, I take, e.g., "4.2.12-7" to be a version string with four components. I also wanted to investigate the single pass, no sort approach. The following solution also retains input order a-la List::MoreUtils::uniq(). (I have no idea if these latter features are required or desired at all, but I wanted to play around with them just as an intellectual exercise.) I can't say I really like this code; three of the map statements | expressions are rather hairy (one is quite long) and I'd hate to be the one who has to maintain this code. Anyway:

use warnings; use strict; use Data::Dump qw(dd); use Test::More 'no_plan'; use Test::NoWarnings; my $ver = qr{ - (\d+) [.] (\d+) [.] (\d+) - (\d+) [.] }xms; my %latest; my @most_recent = map $latest{ $_->[0] }[1] eq $_->[2] ? $_->[2] : (), map { $latest{$_->[0]} = [ @$_[1,2] ] if ! $latest{$_->[0]} or $la +test{$_->[0]}[0] lt $_->[1]; $_; } map [ (m{ \A (.*?) $ver }xms)[0], pack('N4', m{$ver}xms), $_ ], map validate($_), map { chomp; $_; } <DATA> ; dd \@most_recent; is_deeply \@most_recent, [ qw( samba-common-libs-4.2.12-7.el7_2.x86_64 abc-4.2.11-10.el7_2.x86_64 xyz-libs-4.2.13-7.el7_2.x86_64 )], "extracted by most recent version"; done_testing; sub validate { return $_[0]; } # data from Marshall pm#1174121 # also added: # samba-common-libs-4.2.9-8.el7_2.x86_64 # abc-4.2.11-10.el7_2.x86_64 __DATA__ samba-common-libs-4.2.12-7.el7_2.x86_64 samba-common-libs-4.2.10-3.el7_2.x86_64 xyz-libs-4.2.10-7.el7_2.x86_64 samba-common-libs-4.2.10-6.el7_2.x86_64 abc-4.2.11-7.el7_2.x86_64 samba-common-libs-4.2.9-8.el7_2.x86_64 abc-4.2.11-10.el7_2.x86_64 xyz-libs-4.2.11-7.el7_2.x86_64 abc-4.2.11-8.el7_2.x86_64 samba-common-libs-4.2.10-6.2.el7_2.x86_64 xyz-libs-4.2.12-7.el7_2.x86_64 xyz-libs-4.2.13-7.el7_2.x86_64 samba-common-libs-4.2.10-8.el7_2.x86_64
(This runs under 5.8.9.)

Output:

c:\@Work\Perl\monks\Anonymous Monk\1173958>perl sort_by_ver_latest_3.p +l [ "samba-common-libs-4.2.12-7.el7_2.x86_64", "abc-4.2.11-10.el7_2.x86_64", "xyz-libs-4.2.13-7.el7_2.x86_64", ] ok 1 - extracted by most recent version 1..1 ok 2 - no warnings 1..2


Give a man a fish:  <%-{-{-{-<

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://1174125]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others making s'mores by the fire in the courtyard of the Monastery: (3)
As of 2024-04-26 02:38 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found