<?php
function snake($k,$y,$str1,$str2){
$x = $y - $k;
while($x < mb_strlen($str1) && $y < mb_strlen($str2) && $str1[$x] == $str2[$y]){
$x++;
$y++;
}
return $y;
}
function edit_distance_onp($str1, $str2){
$s1 = mb_strlen($str1) > mb_strlen($str2) ? $str2 : $str1;
$s2 = mb_strlen($str1) > mb_strlen($str2) ? $str1 : $str2;
$fp = array();
$x = 0;
$y = 0;
$k = 0;
$p = 0;
$offset = mb_strlen($s1) + 1;
$delta = mb_strlen($s2) - mb_strlen($s1);
for ($i = 0; $i < 100; $i++)
$fp[$i] = -1;
for ($p = 0; $fp[$delta + $offset] != mb_strlen($s2); $p++) {
for($k = -$p; $k < $delta; $k++)
$fp[$k + $offset] = snake($k, max($fp[$k-1+$offset] + 1, $fp[$k+1+$offset]), $s1, $s2);
for($k = $delta + $p; $k > $delta; $k--)
$fp[$k + $offset] = snake($k, max($fp[$k-1+$offset] + 1, $fp[$k+1+$offset]), $s1, $s2);
$fp[$delta + $offset] = snake($delta, max($fp[$delta-1+$offset] + 1, $fp[$delta+1+$offset]), $s1, $s2);
}
return $delta + ($p - 1) * 2;
}
echo edit_distance_onp("qwerty","qwerty");
?>
- Output for 4.3.0 - 4.3.11, 4.4.0 - 4.4.9, 5.0.0 - 5.0.5, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29, 5.4.0 - 5.4.45, 5.5.0 - 5.5.38, 5.6.0 - 5.6.40, 7.0.0 - 7.0.33, 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.18, 8.3.0 - 8.3.6
- 0
preferences:
244.83 ms | 406 KiB | 460 Q