> 백엔드 개발 > PHP 튜토리얼 > PHP 배열에서 중복된 값을 필터링하는 PHP 배열 구현 코드

PHP 배열에서 중복된 값을 필터링하는 PHP 배열 구현 코드

WBOY
풀어 주다: 2016-07-29 08:46:14
원래의
1009명이 탐색했습니다.

复代码 代码如下:


$arrF = array();
$arrS = 배열();
$intTotal = 100;
$intRand = 10;
for($i=0; $i < $intTotal; $i )
{
$arrF[] = rand(1, $intRand);
$arrS[] = rand(1, $intRand);
}
$arrT = array_merge($arrF, $arrS);
$arrRF = 배열();
$intStart = 시간();
foreach($arrT as $v)
{
if(in_array($v, $arrRF))
{
continue;
}
else
{
$arrRF[] = $v;
}
}
$intEnd = time();
$intTime = $intEnd-$intStart;
echo "계속하면 소요 시간:$intTime
";
$intStart1 = 시간();
$arrRS = array_unique($arrT);
$intEnd2 = 시간();
$intTime2 = $intEnd2-$intStart1;
echo "array_unique 함수를 사용하면 소요 시간:($intTime2)";
echo "

"; <br>print_r($arrT); <br>print_r($arrRF); <br>print_r($arrRS); <br>echo "
";
?>


$intTotal比较작은정정况下,比如说1000以内,$intRand的取值基本不影响结果,两者执行的时间差不多。
测试$intTo tal 大于10000时,$intRand取值100时,使用array_unique的效率要高于foreach循环判断,$intRand=10,两者执行时间一致。
容weight不大,大概 1000以内时,使使应该到什么值,我没有详细测试,感兴趣的可以确定一下这个值),随着$intRand的逐渐增大, array_unique的表现更好,我不使用$intTotal/$intRand这个比值,是因为,感觉并不是成比例变化,但是基本会遵循比值越大,array_unique表现越好。
综上所述,지금过滤数组复值的时候,建议使用array_unuique, 数组不大的时候两者效率等同,而array_unique使用当然让你的代码一下子减了好几行,数组容weight过大时,函数的表现更好,为什么不用呢?
以上就介绍了php数组 过滤掉PHP数组中的实现代码, 包括了php数组绍了php数容, 希望对PHP教程有兴趣的朋友多所帮助。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿