in reply to Re: Help in using arrays
in thread Help in using arrays
I suppose you have written it this way to stay close to the OP's coding style, but it should be mentioned that indexing the @all array is not necessary and not particularly perlish.while (<DATA>) { my $code = (split)[1]; for my $x (0..$#all) { if($code eq $all[$x]) { print $_; last; } } }
Now it becomes apparent that what the loop does is really a grep operation:while (<DATA>) { my $code = (split)[1]; for my $x ( @all ) { if($code eq $x) { print $_; last; } } }
Finally, it turns out that grep can be replaced with a hash lookup when the list @all is replaced by a hash:while (<DATA>) { my $code = (split)[1]; print if grep $_ eq $code, @all; } }
Annomy %all = map +( $_ => 1), qw(7723 7725 9908 7765 7874); $all{ (split)[ 1]} and print while <DATA>;
Update: Stylistic change, pomposity tuned down a notch.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^3: Help in using arrays
by davorg (Chancellor) on Mar 14, 2007 at 15:08 UTC | |
by Anno (Deacon) on Mar 14, 2007 at 15:13 UTC |