3v4l.org

run code in 300+ PHP versions simultaneously
<?php function findMyThing($needle, $haystack) { // We need to set up a stack array + a while loop to avoid recursive functions for those are evil. // Recursive functions would also complicate things further in regard of returning. $stack = [ [ 'prefix' => [], 'value' => $haystack ] ]; // As long as there's still something there, don't stop while(count($stack) > 0) { // Copy the current stack and create a new, empty one $currentStack = $stack; $stack = []; // Work the stack for($i = 0; $i < count($currentStack); $i++) { // Iterate over the actual array foreach($currentStack[$i]['value'] as $key => $value) { // If the value is an array, then // 1. the key is a string (so we need to match against it) // 2. we might have to go deeper if(is_array($value)) { // We need to build the current prefix list regardless of what we're gonna do below $prefix = $currentStack[$i]['prefix']; $prefix[] = $key; // If the current key, is the one we're looking for, heureka! if($key == $needle) { return $prefix; } // Otherwise, push prefix & value onto the stack for the next loop to pick up else { $stack[] = [ 'prefix' => $prefix, 'value' => $value ]; } } // If the value is NOT an array, then // 1. the key is an integer, so we DO NOT want to match against it // 2. we need to match against the value itself elseif($value == $needle) { // This time append $value, not $key $prefix = $currentStack[$i]['prefix']; $prefix[] = $value; return $prefix; } } } } // At this point we searched the entire array and didn't find anything, so we return an empty array return []; } $arr = [ 'USA' => [ 'Alabama' => [ 'Montgomery', 'Birmingham' ], 'Arizona' => [ 'Phoenix', 'Mesa', 'Gilbert' ] ], 'Germany' => [ 'West Germany' => [ 'Bonn', 'Cologne' ] ] ]; print_r(findMyThing('Alabama', $arr)); print_r(findMyThing('Cologne', $arr));
Output for 5.4.0 - 5.4.45, 5.5.24 - 5.5.35, 5.6.7 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.20, 7.2.0 - 7.2.33, 7.3.16 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.4, 8.3.6
Array ( [0] => USA [1] => Alabama ) Array ( [0] => Germany [1] => West Germany [2] => Cologne )
Output for 8.3.5
Warning: PHP Startup: Unable to load dynamic library 'sodium.so' (tried: /usr/lib/php/8.3.5/modules/sodium.so (libsodium.so.23: cannot open shared object file: No such file or directory), /usr/lib/php/8.3.5/modules/sodium.so.so (/usr/lib/php/8.3.5/modules/sodium.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0 Array ( [0] => USA [1] => Alabama ) Array ( [0] => Germany [1] => West Germany [2] => Cologne )
Output for 4.4.2 - 4.4.9, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29
Parse error: syntax error, unexpected '[' in /in/EFTSk on line 8
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1, 5.0.0 - 5.0.5
Parse error: parse error, unexpected '[' in /in/EFTSk on line 8
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error in /in/EFTSk on line 8
Process exited with code 255.

preferences:
269.76 ms | 401 KiB | 313 Q