取数组中一段值的算法(转)

假设数组有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 ?>

 

posted @ 2013-12-09 09:54  幻星宇  阅读(387)  评论(0编辑  收藏  举报