• php多维数组化一维数组


    一、使用foreach

    <?php
       function arr_foreach ($arr)
       {
          static $tmp=array(); 
          if (!is_array ($arr))
          {
             return false;
          }
          foreach ($arr as $val )
          {
             if (is_array ($val))
             {
                arr_foreach ($val);
             }
             else
             {
                $tmp[]=$val;
             }
          }
          return $tmp;
       }
       $a = array(1,2=>array(3,4=>array(5,6)),7);
       print_r(arr_foreach($a));
    ?>
    

     二、使用for循环,只能遍历数字下标的数组

    <?php
       function arr_foreach($arr)
       {
          static $tmp=array(); 
    
          for($i=0; $i<count($arr); $i++)
          { 
             if(is_array($arr[$i]))
             { 
                arr_foreach($arr[$i]); 
             }else{ 
                $tmp[]=$arr[$i]; 
             } 
          } 
    
          return $tmp; 
       }
       //调用例子
       $a = array(1,array(3,array(5,6)),7);
       print_r(arr_foreach($a));
    ?>
    

     三、使用while

     1 /**
     2  * 将多维数组转为一维数组
     3  * @author echo
     4  * @link http://www.jb51.net/
     5  * @param array $arr
     6  * @return array
     7  */
     8 function ArrMd2Ud($arr) {
     9  #将数值第一元素作为容器,作地址赋值。
    10  $ar_room = &$arr[key($arr)];
    11  #第一容器不是数组进去转呀
    12  if (!is_array($ar_room)) {
    13   #转为成数组
    14   $ar_room = array($ar_room);
    15  }
    16  #指针下移
    17  next($arr);
    18  #遍历
    19  while (list($k, $v) = each($arr)) {
    20   #是数组就递归深挖,不是就转成数组
    21   $v = is_array($v) ? call_user_func(__FUNCTION__, $v) : array($v);
    22   #递归合并
    23   $ar_room = array_merge_recursive($ar_room, $v);
    24   #释放当前下标的数组元素
    25   unset($arr[$k]);
    26  }
    27  return $ar_room;
    28 }
  • 相关阅读:
    NOI2010 能量采集
    NOI2011 兔兔与蛋蛋游戏
    动态规划——min/max的单调性优化总结
    NOI2011 NOI嘉年华
    NOI2011 阿狸的打字机
    NOI2011 智能车比赛
    NOI2011 兔农
    NOI2012 魔幻棋盘
    NOI2012 美食节
    NOI2012 迷失游乐园
  • 原文地址:https://www.cnblogs.com/zoubizhici/p/5598136.html
Copyright © 2020-2023  润新知