用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - php代码库

php levenshtein 算法原理

2014-11-30 作者: php源代码大全举报

[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


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...