zoukankan      html  css  js  c++  java
  • php 把一个数组分成有n个元素的二维数组的算法

    一、第一种解法

             

    <?php 
       //把一个数组分成几个数组
       //$arr 是数组
       //$num 是数组的个数
       function partition($arr,$num){
         //数组的个数
         $listcount=count($arr);
         //分成$num 个数组每一个数组是多少个元素
         $parem=floor($listcount/$num);
         //分成$num 个数组还余多少个元素
         $paremm=$listcount%$num;
         $start=0;
         for($i=0;$i<$num;$i++){
            $end=$i<$paremm?

    $parem+1:$parem; $newarray[$i]=array_slice($arr,$start,$end); $start=$start+$end; } return $newarray; } $arr=array(1,3,4,5,6,7,8,9,2); print_r(partition($arr,3));


    二、另外一种解法是模拟现实生活中怎样把一个一维数组拆分成n个元素的多维数组。代码入下。

         

      function get_array_columns($array, $columns){
        $columns_map=array();
        for($i=0;$i<$columns;$i++){
          $columns_map[]=0;
        }
        $array_length=count($array);
        $position=0;
        while($array_length>0){
            $columns_map[$position]++;
            //这个地方格外注意,$position与$columns比較
            $position=($position<$columns-1)?++$position:0;
            $array_length--;
        }
        foreach ($columns_map as $val){
          $newarray[]=array_splice($array,0,$val);
        }
        return $newarray;
      }
      
      $arr=array(1,2,3,4,5,6,7,8);
      print_r(call_user_func_array('get_array_columns',array($arr,2)));

  • 相关阅读:
    飞跃平野(sdut1124)
    背包
    sdut2193救基友记3(三维)
    hdu1542 Atlantis(矩阵面积的并)
    hdu1505City Game(扫描线)
    poj3468A Simple Problem with Integers(线段树的区域更新)
    hdu1166敌兵布阵&&hdu1754I Hate It(线段树入门)
    Biorhythms(中国剩余定理)
    Sequence(priority_queue)
    Message Flood(map)
  • 原文地址:https://www.cnblogs.com/jhcelue/p/7133168.html
Copyright © 2011-2022 走看看