取数组中一段值的算法

假设数组有1000个元素,键值为小于1000000的无序的正整数,且不连续,如下$arr=array(1=>'sadas',20=>'aasd',5002=>'fghfg',190023=>'rty',248=>'kj',76=>'sddd'...);
现在要获取数组$arr中键的值大于500小于600的元素,不用foreach完全循环一遍的话是否有更高效的算法?

 1 <?php

 2 /**

 3 *获取指定范围下标的数组

 4 *@params $arr  原数组

 5 *@params $start  开始下标

 6 *@params $end    结束下标

 7 *[url=u.php?uid=5527]@return[/url]   返回指定下标范围的数组 

 8 */

 9 function getByKeyRang($arr, $start, $end){

10 $return_keys = range($start, $end);

11 $return_keys = array_flip($return_keys);

12 return array_intersect_key($arr, $return_keys);

13 }

14 

15 //测试

16 $arr = array(1=>'sadas',20=>'aasd',5002=>'fghfg', 580=>'dfgfdg', 190023=>'rty',248=>'kj',76=>'sddd',606=>'sddd', 505=>'dfgfdg');

17 var_dump(getByKeyRang($arr, 501, 599));

18 ?>

 

你可能感兴趣的:(算法)