Beefy Boxes and Bandwidth Generously Provided by pair Networks
Problems? Is your data what you think it is?
 
PerlMonks  

Re: Explain the code

by gopalr (Priest)
on Jul 24, 2008 at 12:54 UTC ( #699861=note: print w/ replies, xml ) Need Help??


in reply to Explain the code

This approach is merges the construction of the %seen hash with the extraction of unique elements.

1. reading elements from @array

2. If the current element ($_) and it is not in the hash (%seen), it will push into @result. Then it stored into hash(%seen). As we know hash will not allow duplicate value

Thanks
Gopal


Comment on Re: Explain the code
Re^2: Explain the code
by olus (Curate) on Jul 24, 2008 at 12:58 UTC

    %seen will also have the number of occurrences of every element of @a.

      How? If the array (@a) has duplicate values, hash will eliminate that.

        The ++ is evaluated for every item in @a, grep only checks its return value and picks (or not picks) the element based on that value.
        $seen{4} = 3 means that 4 has been seen 3 times.

        Unless I state otherwise, all my code runs with strict and warnings

        Noticed the ++ in !$seen{$_}++?

        perl -MData::Dumper -e '@a=(1, 2, 1, 2, 3); my @result = grep { !$seen +{$_}++ } @a; print Dumper(\%seen);' $VAR1 = { '1' => 2, '3' => 1, '2' => 2 };

Log In?
Username:
Password:

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

How do I use this? | Other CB clients
Other Users?
Others contemplating the Monastery: (15)
As of 2014-08-22 17:41 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    The best computer themed movie is:











    Results (162 votes), past polls