php levenshtein,php levenshtein 算法原理

[php]代码库//Levenshtein算法,用于计算两个字符串之间的Levenshtein距离。而Levenshtein距离又称为编辑距离,是指两个字符串之间,由一个转换成另一个所需的最少编辑操作次数。许可的编辑操作包括将一个字符替换成另一个字符,插入一个字符,删除一个字符。

function _levenshtein($src, $dst){

if (empty($src)) {

return $dst;

}

if (empty($dst)) {

return $src;

}

$temp = array();

for($i = 0; $i <= strlen($src); $i++) {

$temp[$i][0] = $i;

}

for($j = 0; $j <= strlen($dst); $j++) {

$temp[0][$j] = $j;

}

for ($i = 1;$i <= strlen($src); $i++) {

$src_i = $src{$i - 1};

for ($j = 1; $j <= strlen($dst); $j++) {

$dst_j = $dst{$j - 1};

if ($src_i == $dst_j) {

$cost = 0;

} else {

$cost = 1;

}

$temp[$i][$j] = min($temp[$i-1][$j]+1, $temp[$i][$j-1]+1, $temp[$i-1][$j-1] + $cost);

}

}

return $temp[$i-1][$j-1];

}

echo _levenshtein("hello", "HElloo");

//该片段来自于http://yuncode.net

694748ed64b9390909c0d88230893790.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值