|
一般的做法就會(huì)這樣:
復(fù)制代碼 代碼如下:
<?php
for ($offset = 0; $offset < $length; ++$offset) {
if ($str1[$offset] !== $str2[$offset]) {
return $offset;
}
}
而問題下面給出的最佳答案是用異或操作符( ^ ),以前從來沒用過這個(gè)操作符,也不知道能用到什么地方,今天算是學(xué)到。
因?yàn)橐话闱闆r下,當(dāng)你對(duì)兩個(gè)字符串進(jìn)行異或操作的時(shí)候,相同的字符的異或結(jié)果是null(“/0”),所以我們只要找出第一個(gè)非null(“/0”)字符就可以了。
復(fù)制代碼 代碼如下:
<?php
$position = strspn($string1 ^ $string2, "/0");
很明顯這是一個(gè)更優(yōu)雅高效的方法。 另外,回答的人還附加了一個(gè)多字節(jié)字符的解決辦法。
復(fù)制代碼 代碼如下:
<?php
function getCharacterOffsetOfDifference($str1, $str2, $encoding = 'UTF-8') {
return mb_strlen($str1, $encoding)
- mb_strlen(
mb_strcut(
$str1,
strspn($str1 ^ $str2, "/0"),
mb_strlen($str1, '8bit'),
$encoding
),
$encoding
);
}
php技術(shù):PHP中比較兩個(gè)字符串找出第一個(gè)不同字符位置例子,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。