过滤掉PHP数组中的重复值的实现代码
2011-07-17 00:00
736 查看
<?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<br/>"; $intStart1 = time(); $arrRS = array_unique($arrT); $intEnd2 = time(); $intTime2 = $intEnd2-$intStart1; echo "With array_unique function,Spend time:($intTime2)"; echo "<pre>"; print_r($arrT); print_r($arrRF); print_r($arrRS); echo "</pre>"; ?>
在$intTotal比较小的情况下,比如说1000以内,$intRand的取值基本不影响结果,两者执行的时间都差不多。
测试$intTotal 大于10000时,$intRand取值100时,使用array_unique的效率要高于foreach循环判断,$intRand=10,两者执行时间一致。
因此,可以得出结论,当数组容量不大,大概在1000以内时,使用两者的执行效率差不多。
当数组容量比较大时(具体应该到什么值,我没有详细测试,感兴趣的可以确定一下这个值),随着$intRand的逐渐增大,array_unique的表现更好,我不使用$intTotal/$intRand这个比值,是因为,感觉并不是成比例变化,但是基本会遵循比值越大,array_unique表现越好。
综上所述,在过滤数组重复值的时候,建议使用array_unuique,数组不大的时候两者效率等同,而array_unique使用当然让你的代码一下子减了好几行,数组容量过大时,函数的表现更好,为什么不用呢?
相关文章推荐
- php中使用array_filter()函数过滤空数组的实现代码
- php中使用array_filter()函数过滤空数组的实现代码
- php实现数组纵向转横向并过滤重复值的方法分析
- php数组对百万数据进行排除重复数据的实现代码
- javascript下过滤数组重复值的代码
- PHP实现将MySQL重复ID二维数组重组为三维数组的方法
- ASP.NET数组删除重复值实现代码
- php数组去重复代码
- php中显示数组与对象的实现代码
- PHP中使用数组实现堆栈数据结构的代码
- php实现数组重复数字统计实例
- PHP将数组转成XML格式的实现代码
- 基于jquery的选择标签至文本域效果,可多选/可过滤重复/可限制个数的实现代码
- javascript下过滤数组重复值的代码
- JS数组去掉重复数据只保留一条的实现代码
- PHP获取数组中重复最多的元素的实现方法
- PHP 简单数组排序实现代码