PHP中如何获得数组中指定元素的前一个或后一个元素

方法一:用循环

function getNext(&$array, $curr_key)
{
    $next = 0;
    reset($array);

    do
    {
        $tmp_key = key($array);
        $res = next($array);
    } while ( ($tmp_key != $curr_key) && $res );

    if( $res )
    {
        $next = key($array);
    }

    return $next;
}

function getPrev(&$array, $curr_key)
{
    end($array);
    $prev = key($array);

    do
    {
        $tmp_key = key($array);
        $res = prev($array);
    } while ( ($tmp_key != $curr_key) && $res );

    if( $res )
    {
        $prev = key($array);
    }

    return $prev;
}

方法二:用Iterator,不过要先得到position

// 默认查找键为key元素的后一个元素
function get_element($key, $arr, $who='next')
{
    //查找键为$key元素的位置
    $offset = array_search($key, array_keys($arr));
    if(FALSE == $offset || NULL == $offset) { return ;}

    //查找哪个元素,前一个或后一个?
    if ('prev' == $who) {
        $arr = array_reverse($arr);
    } else if ('next' == $who) {

    } else {
        throw new Exception("错误的参数");
    }

    $iterator = new ArrayIterator($arr);
    $iterator->seek($offset);
    $iterator->next();

    //返回数组当前指针指向元素的键值数组
    return array($iterator->key(), $iterator->current());
}

$arr = array('foo' => 10, 'bar' => 45, 'baz' => 23);
$key ='bar';

print_r(get_element($key, $arr));

方法三:老风给的方法

我按照老风的意思写的:

function get_element($key, $array, $who='next') {
 //先获取key 的位置
  $arr_keys = array_keys($array);
    $arr_keys_flip = array_flip($arr_keys);

    if (array_key_exists($key, $arr_keys_flip)) {
        $location = $arr_keys_flip[$key];//返回KEY的位置
    } else {
        throw new Exception("数组中不存在此键");
    }

   $arr_values = array_values($array);

    //查找哪个元素,前一个或后一个?
    if ('prev' == $who) {
        $pos = $location-1;
    } else if ('next' == $who) {
        $pos = $location+1;
    } else {
        throw new Exception("错误的参数");
    }

 return array($arr_keys[$pos], $arr_values[$pos]);
}

老风觉得太长,又优化了一遍

function get_element($key, $array, $who='next'){
  $arr_keys = array_keys($array);
   $arr_keys_flip = array_flip($arr_keys);
   $location = (array_key_exists($key,$arr_keys_flip))?$arr_keys_flip[$key]:die('数组中不存在此键');
 $arr_values = array_values($array);
   $info = array('prev'=>$location-1,'next'=>$location+1);
   $pos = (array_key_exists($who,$info))?$info[$who]:die('错误的参数');
   return array($arr_keys[$pos], $arr_values[$pos]);
}

经过效率测试,方法二的效率最高,不过仍然存在瓶颈,那就是array\_keys函数,因此如果此处使用foreach取得location将会大大提高效率:

function get_element($key, $arr, $who='next')
{
    //查找键为$key元素的位置
    $offset = 0;
    foreach ($arr as $_k => $_v) {
        if($_k == $key) break;++$offset;
    }

    //查找哪个元素,前一个或后一个?
    if ('prev' == $who) {
        $arr = array_reverse($arr);
    } else if ('next' == $who) {

    } else {
        throw new Exception("错误的参数");
    }

    $iterator = new ArrayIterator($arr);
    $iterator->seek($offset);
    $iterator->next();

    //返回数组当前指针指向元素的键值数组
    return array($iterator->key(), $iterator->current());
}