Beefy Boxes and Bandwidth Generously Provided by pair Networks
Do you know where your variables are?
 
PerlMonks  

Re: Finding the max()/min()

by tmoertel (Chaplain)
on Nov 11, 2004 at 05:12 UTC ( [id://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

Log In?
Username:
Password:

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

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

    No recent polls found