Beefy Boxes and Bandwidth Generously Provided by pair Networks
"be consistent"
 
PerlMonks  

Re: How to get a ideal hash

by rir (Vicar)
on Apr 08, 2009 at 18:53 UTC ( #756416=note: print w/ replies, xml ) Need Help??


in reply to How to get a ideal hash

Be well,
rir

#!/usr/bin/perl use strict; use warnings; use Data::Dumper; my $h = { 4 => -1, 2 => 6, 6 => 4, 3 => 5, 5 => -1, 99 => -1 }; sub LEAF() { -1 } # Make a list of toplevel keys: values occurring once and not LEAF my %tl; ++$tl{$_} for grep { $_ != LEAF } %$h ; my @toplevel = grep { $tl{$_} == 1 } keys %tl; # Build linked lists from head as HoHo... my %answer = (); for my $k ( @toplevel ) { my $cursor = \%answer; $cursor->{$k} = $h->{$k}; while ( LEAF != ( my $next_k = $cursor->{$k}) ) { $cursor = $cursor->{$k} = { $next_k, $h->{ $next_k } }; $k = $next_k; } } print Dumper \%answer;


Comment on Re: How to get a ideal hash
Download Code

Log In?
Username:
Password:

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

How do I use this? | Other CB clients
Other Users?
Others taking refuge in the Monastery: (7)
As of 2014-12-23 04:52 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    Is guessing a good strategy for surviving in the IT business?





    Results (135 votes), past polls