PHP levenshtein() 函數(shù)
PHP levenshtein() 函數(shù)
實(shí)例
計(jì)算兩個(gè)字符串之間的 Levenshtein 距離:
<?php
echo levenshtein("Hello World","ello World");
echo "<br>";
echo levenshtein("Hello World","ello World",10,20,30);
?>
運(yùn)行實(shí)例 ?
定義和用法
levenshtein() 函數(shù)返回兩個(gè)字符串之間的 Levenshtein 距離。
Levenshtein 距離,又稱編輯距離,指的是兩個(gè)字符串之間,由一個(gè)字符串轉(zhuǎn)換成另一個(gè)字符串所需的最少編輯操作次數(shù)。許可的編輯操作包括將一個(gè)字符替換成另一個(gè)字符,插入一個(gè)字符,刪除一個(gè)字符。
在默認(rèn)情況下,PHP 給每個(gè)操作(替換、插入和刪除)相同的權(quán)重。然而,您可以通過設(shè)置可選的 insert、replace、delete 參數(shù),來定義每個(gè)操作的代價(jià)。
注釋:levenshtein() 函數(shù)是不區(qū)分大小寫的。
注釋:levenshtein() 函數(shù)比 similar_text() 函數(shù)更快。不過,similar_text() 函數(shù)通過更少的必需修改次數(shù)提供更精確的結(jié)果。
語法
levenshtein(string1,string2,insert,replace,delete)
參數(shù) | 描述 |
---|---|
string1 | 必需。要比較的第一個(gè)字符串。 |
string2 | 必需。要比較的第二個(gè)字符串。 |
insert | 可選。插入一個(gè)字符的代價(jià)。默認(rèn)是 1。 |
replace | 可選。替換一個(gè)字符的代價(jià)。默認(rèn)是 1。 |
delete | 可選。刪除一個(gè)字符的代價(jià)。默認(rèn)是 1。 |
技術(shù)細(xì)節(jié)
返回值: | 返回兩個(gè)參數(shù)字符串之間的 Levenshtein 距離,如果其中一個(gè)字符串超過 255 個(gè)字符,則返回 -1。 |
---|---|
PHP 版本: | 4.0.1+ |

相關(guān)文章
- PHP 變量
- PHP 數(shù)據(jù)類型
- PHP date() 函數(shù)
- PHP 文件處理
- PHP Secure E-mails
- PHP 異常處理
- PHP array() 函數(shù)
- PHP array_intersect_uassoc() 函數(shù)
- PHP array_key_exists() 函數(shù)
- PHP array_key_first() 函數(shù)
- PHP array_merge() 函數(shù)
- PHP array_merge_recursive() 函數(shù)
- PHP array_product() 函數(shù)
- PHP array_walk() 函數(shù)
- PHP arsort() 函數(shù)
- PHP asort() 函數(shù)
- PHP krsort() 函數(shù)
- PHP pos() 函數(shù)
- PHP prev() 函數(shù)
- PHP HTTP 函數(shù)