zoukankan      html  css  js  c++  java
  • php 自己实现数组翻转

    php里面有个函数可以反转数组,工作中也经常用到,非常方便。今天来自己实现这样的功能。

     
    $arr = [2,5,6,1,8,16,12];
    function reverse($arr){
        $left = 0;
        $right = count($arr) -1;
        $temp = [];
        while ($left <= $right){
            $temp[$left] = $arr[$right];
            $temp[$right]  = $arr[$left];
            $left++;
            $right--;
        }
        ksort($temp);
        return $temp;
    }
     
    效果
     
    Array
    (
        [0] => 12
        [1] => 16
        [2] => 8
        [4] => 6
        [5] => 5
        [6] => 2
    )
     

     不过这个函数只能处理一维数组。在实现一个可以处理多维的。

     
    $arr = [2,[6,3,9],1,[5,2,1,[10,8,7]],5,0];
     
    function reverse_arr($arr){
        $index = 0;
        $reverse_array = [];
        foreach ($arr as $sub_arr){
            if(is_array($sub_arr)){
                $sub_arr = reverse($sub_arr);
                $arr_ = reverse_arr($sub_arr);
                $reverse_array[$index] = $arr_;
            }else{
                $reverse_array[$index] = $sub_arr;
            }
            $index++;
        }
        return $reverse_array;
    }
     
    print_r(reverse(reverse_arr($arr)));<br><br>输出结果
    Array
    (
    [0] => 0
    [1] => 5
    [2] => Array
    (
    [0] => Array
    (
    [0] => 7
    [1] => 8
    [2] => 10
    )

    [1] => 1
    [2] => 2
    [3] => 5
    )

    [3] => 1
    [4] => Array
    (
    [0] => 9
    [1] => 3
    [2] => 6
    )

    [5] => 2
    )
     

    上面都是数字索引数组,不能处理关联数组,接着来个可以处理关联数组的

     
    $arr = ['a'=>'aa','b'=>'bb','c'=>'cc','d'=>'dd','e'=>'ee'];
    function reverse($arr){
        $temp = [];
        end($arr);
        while (($value = current($arr)) != null){
            $temp[key($arr)] = $value;
            prev($arr);
        }
        return $temp;
    }
    print_r(reverse($arr));
     
    结果
    Array
    (
        [e] => ee
        [d] => dd
        [c] => cc
        [b] => bb
        [a] => aa
    )

  • 相关阅读:
    【洛谷P3629】巡逻【树的直径】
    【洛谷P3629】巡逻【树的直径】
    【洛谷P4408】逃学的小孩【树的直径】
    【洛谷P4408】逃学的小孩【树的直径】
    【POJ2631】Roads in the North【树的直径】
    【POJ2631】Roads in the North【树的直径】
    【洛谷P1547】Out of Hay【最小生成树】
    【洛谷P1547】Out of Hay【最小生成树】
    【USACO2.3.1】【洛谷P1470】最长前缀【KMP】
    【USACO2.3.1】【洛谷P1470】最长前缀【KMP】
  • 原文地址:https://www.cnblogs.com/xiaogou/p/9121995.html
Copyright © 2011-2022 走看看