3v4l.org

run code in 300+ PHP versions simultaneously
<?php function buildRegexFrom(string $word): string { // Split word to letters $letters = str_split($word); // Creating all side of alternations in our regex foreach ($letters as $key => $letter) if (end($letters) != $letter) $regex[] = "$letter(?={$letters[$key + 1]})|(?<=$letter){$letters[$key + 1]}"; // Return whole cooked pattern return "~(?|((?>".implode('|', $regex).")+)|([$word]))~i"; } function longestSubstring(array $array, string $regex): array { foreach ($array as $value) { preg_match_all($regex, $value, $matches); usort($matches[1], function($a, $b) { return strlen($b) <=> strlen($a); }); // Store longest match being sorted $substrings[] = $matches[1][0]; } return $substrings; } print_r(longestSubstring(['Mymaxmuis', 'axmuis', 'muster'], buildRegexFrom('maxmuster')));
Output for 7.0.0 - 7.0.20, 7.1.0 - 7.1.33, 7.2.0 - 7.2.33, 7.3.0 - 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.19, 8.3.0 - 8.3.7
Array ( [0] => maxmu [1] => axmu [2] => muster )

preferences:
172.86 ms | 404 KiB | 216 Q