Given an Array of Arrays of letters as $g = \@grid, with 'height' $h and width $w, and a word to look for in that grid as $p. All characters are in uppercase.
Find the perl golf solution that locates that word in the grid. The output should be an array; the first two items are the across and down positions in the grid, given the top-left corner is at 0,0; the remaining parameters may be one of the following (whichever makes the golf easist to solve - you only need to have the return in one of these formats, and assume the rest of the program can handle the format you choose):
Example usage:
my @grid = ( [ split( //, 'ABPR' ) ], [ split( //, 'CAEL' ) ], [ split( //, 'TSRX' ) ], [ split( //, 'OILW' ) ] ); my $h = 4; my $w = 4; sub find { ... } my @results = find( \@grid, $w, $h, "PERL" ); # # @results can be: # ( 2, 0, 4 ) if using 1-8 numbers # ( 2, 0, 0, 1 ) if using direction # ( 2, 0, 2, 3 ) if using end point my @results = find( \@grid, $w, $h, "GOLD" ); # @results = ()
Update - Fixed order of width/height passage, and an error in one of the example.
-----------------------------------------------------
Dr. Michael K. Neylon - mneylon-pm@masemware.com
||
"You've left the lens cap of your mind on again, Pinky" - The Brain
It's not what you know, but knowing how to find it if you don't know that's important
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: (Golf) Word Search Solver
by chipmunk (Parson) on Aug 30, 2001 at 00:54 UTC | |
|
Re: (Golf) Word Search Solver
by dragonchild (Archbishop) on Aug 29, 2001 at 21:30 UTC |