天天看點

php過濾數組中重複的值_PHP數組中的重複值過濾的實作方法

函數從數組中過濾重複值并傳回結果數組,當多個數組元素的值相等時,隻保留第一個元素,會過濾了其他元素,下文是愛站技術頻道小編為您整理的PHP數組中的重複值過濾的實作方法,一起進入下文了解一下吧!

複制代碼 代碼如下:

$arrF = array();

$arrS = array();

$intTotal = 100;

$intRand = 10;

for($i=0; $i < $intTotal; $i++)

{

$arrF[] = rand(1, $intRand);

$arrS[] = rand(1, $intRand);

}

$arrT = array_merge($arrF, $arrS);

$arrRF = array();

$intStart = time();

foreach($arrT as $v)

{

if(in_array($v, $arrRF))

{

continue;

}

else

{

$arrRF[] = $v;

}

}

$intEnd = time();

$intTime = $intEnd-$intStart;

echo "With Continue,Spend time:$intTime

";

$intStart1 = time();

$arrRS = array_unique($arrT);

$intEnd2 = time();

$intTime2 = $intEnd2-$intStart1;

echo "With array_unique function,Spend time:($intTime2)";

echo "

";      

print_r($arrT);

print_r($arrRF);

print_r($arrRS);

echo "

";

?>

在$intTotal比較小的情況下,比如說1000以内,$intRand的取值基本不影響結果,兩者執行的時間都差不多。

測試$intTotal 大于10000時,$intRand取值100時,使用array_unique的效率要高于foreach循環判斷,$intRand=10,兩者執行時間一緻。

是以,可以得出結論,當數組容量不大,大概在1000以内時,使用兩者的執行效率差不多。

當數組容量比較大時(具體應該到什麼值,我沒有詳細測試,感興趣的可以确定一下這個值),随着$intRand的逐漸增大,array_unique的表現更好,我不使用$intTotal/$intRand這個比值,是因為,感覺并不是成比例變化,但是基本會遵循比值越大,array_unique表現越好。

上文是PHP數組中的重複值過濾的實作方法,相信大家都有了一定的了解,想要了解更多的技術資訊,請繼續關注愛站技術頻道吧!