2

我需要递归地反转具有许多级别子数组的 HUGE 数组,并且我需要保留所有键(其中一些是 int 键,有些是字符串键),有人可以帮我吗?也许以某种方式使用 array_reverse 的示例?另外,使用 array_reverse 是唯一/最好的方法吗?

谢谢 :)

4

3 回答 3

11

试试这个:

function array_reverse_recursive($arr) {
    foreach ($arr as $key => $val) {
        if (is_array($val))
            $arr[$key] = array_reverse_recursive($val);
    }
    return array_reverse($arr);
}
于 2010-11-05T05:55:19.727 回答
1

递归:

<?php

$a = array(1,3,5,7,9);

print_r($a);

function rev($a) {
  if (count($a) == 1)
    return $a;

  return array_merge(rev(array_slice($a, 1, count($a) - 1)), array_slice($a, 0, 1));
}

$a = rev($a);
print_r($a);

?>

输出:

Array
(
    [0] => 1
    [1] => 3
    [2] => 5
    [3] => 7
    [4] => 9
)
Array
(
    [0] => 9
    [1] => 7
    [2] => 5
    [3] => 3
    [4] => 1
)
于 2010-11-05T06:09:35.137 回答
0

原位反转一个巨大的 php 数组(但不是递归的):

function arrayReverse(&$arr){
  if (!is_array($arr) || empty($arr)) {
    return;
  }
  $rev = array();
  while ( false !== ( $val = end($arr) ) ){
    $rev[ key($arr) ] = $val;
    unset( $arr[ key($arr) ] );
  }
  $arr = $rev;
}
//usage
$test = array(5, 'c'=>100, 10, 15, 20);
arrayReverse($test);
var_export($test);
// result: array ( 3 => 20, 2 => 15, 1 => 10, 'c' => 100, 0 => 5, )
于 2012-06-20T13:39:17.670 回答