3v4l.org

run code in 300+ PHP versions simultaneously
<?php function getNgrams($match, $n = 2) { $nGrams = []; for ($pos = strlen($match) - $n; $pos >= 0; --$pos) { $nGrams[] = substr($match, $pos, $n); } return $nGrams; } $question = 'happy birthday'; $questionNGrams = array_map("getNgrams", explode(' ', $question)); $rta = ['today', 'happy', ' tomorrow ', 'monday', 'birthda']; foreach ($rta as $value) { $rtaNGram = getNgrams($value); $rtaNGramCount = count($rtaNGram); foreach ($questionNGrams as $questionNGram) { if (count(array_intersect($rtaNGram, $questionNGram)) / $rtaNGramCount >= 0.8) { echo "{$value}<br>"; break; } } }

preferences:
28.83 ms | 402 KiB | 5 Q