Beefy Boxes and Bandwidth Generously Provided by pair Networks
There's more than one way to do things
 
PerlMonks  

Re: How to get a ideal hash

by BrowserUk (Patriarch)
on Apr 03, 2009 at 13:08 UTC ( [id://755261]=note: print w/replies, xml ) Need Help??


in reply to How to get a ideal hash

This could probably be simplified a little:

#! perl -sw use strict; use Data::Dump qw[ pp ]; my $h= { (4,-1), (2,6), (6,4), (3,5), (5,-1), (99,-1), }; my %invert; push @{ $invert{ $h->{ $_ } } }, $_ for keys %{ $h }; my %hh; for( @{ $invert{ -1 } } ) { my $ref = { $_, -1 }; while( exists $invert{ $_ } ) { my $key = pop @{ $invert{ $_ } }; $ref = { $key, $ref }; delete $invert{ $_ } unless @{ $invert{ $_ } }; $_ = $key; } my( $key, $value ) = each %$ref; $hh{ $key } = $value; } pp \%hh; __END__ c:\test>755232 { 2 => { 6 => { 4 => -1 } }, 3 => { 5 => -1 }, 9 => -1 }

Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
"Science is about questioning the status quo. Questioning authority".
In the absence of evidence, opinion is indistinguishable from prejudice.

Log In?
Username:
Password:

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

How do I use this?Last hourOther CB clients
Other Users?
Others pondering the Monastery: (5)
As of 2024-04-19 04:47 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found