Beefy Boxes and Bandwidth Generously Provided by pair Networks
more useful options
 
PerlMonks  

Re: Finding the max()/min()

by tmoertel (Chaplain)
on Nov 11, 2004 at 05:12 UTC ( #406927=note: print w/ replies, xml ) Need Help??


in reply to Finding the max()/min()

As others have mentioned, it's handy to capture min and max logic in subroutines for reuse. Most times, if you have a max subroutine, for example, it will take an array and return the maximum element. That's great if you want to hold all of your values in memory, but what if you don't? What if you want to compute your maximum iteratively, e.g., one number at a time while reading from a file?

As I offered in Re: getting the highest value in a simpler way, we can encapsulate our logic inside of a closure-based factory function that makes "maximum finders":

sub make_max_finder { my $max; sub { for (@_) { $max = $_ if !defined $max || $_ > $max } $max; } }
The nice thing about this approach is that the logic is captured in one place and yet we can use it both on big arrays and upon iterated-over data. The array method:
make_max_finder->(1..10); # 10
The iterative, light-on-memory method:
my $max_finder = make_max_finder(); $max_finder->($_) while <>; $max_finder->(); # retrieve maximum

Cheers,
Tom


Comment on Re: Finding the max()/min()
Select or Download Code

Log In?
Username:
Password:

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

How do I use this? | Other CB clients
Other Users?
Others chilling in the Monastery: (3)
As of 2014-08-31 03:24 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    The best computer themed movie is:











    Results (294 votes), past polls