in reply to Returning position?

For ismember, have you considered using a hash instead of an array? Then you could do

my $ismember = exists $hash{string};

If you're going to do a bunch of lookups, you could convert the array to a hash temporarily.

my %hash = map { $_ => $_ } @array; print($hash{string1}, "\n"); print($hash{string2}, "\n"); print($hash{string3}, "\n");

The following returns the index or undefined, but create a list as big as the array in memory.

use List::Util qw( first ); my $idx = first { $array[$_] eq "string" } 0..$#array;

A memory efficient version of the above.

sub ismember { my ($array, $search) = @_; for my $i (0..$#$array) { return $i if $array->[$i] eq $search; } return (); } my $idx = ismember(\@array, "string");

Update: Applied Not_a_Number's fix. Thanks.

Replies are listed 'Best First'.
Re^2: Returning position?
by Not_a_Number (Prior) on Feb 25, 2007 at 13:48 UTC

    In your second snippet:

    my $idx = first { $_ eq "string" } 0..$#array;

    You surely meant to write:

    my $idx = first { $array[$_] eq "string" } 0..$#array;
Re^2: Returning position?
by ikegami (Patriarch) on Feb 25, 2007 at 09:59 UTC

    I meant to mention a binary search would be faster, but that would require @array to be sorted.