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