duanlan7903 2012-11-23 09:12
浏览 56
已采纳

PHP中的数组组合

Consider following array:

$a = [['x'], ['y', 'z', 'w'], ['m', 'n']];

How can generate following array from it:

$output=[
[[x][y][m]],
[[x][z][n]],
[[x][w][m]],
[[x][y][n]],
[[x][z][m]],
[[x][w][n]],
];

I am searching for a more efficient code than mine. (My current code is presented as an answer below)

  • 写回答

5条回答 默认 最新

  • dqtm8504 2012-11-23 10:05
    关注

    Here we go. Assuming:

    $array = [['x'], ['y', 'z', 'w'], ['m', 'n']];
    

    EDIT: After some performance testing, I concluded the solution I posted before is about 300% slower than OP's code, surely due to nested function call stacking. So here is an improved version of OP's approach, which is around 40% faster:

    $count     = array_map('count', $array);
    $finalSize = array_product($count);
    $arraySize = count($array);
    $output    = array_fill(0, $finalSize, []);
    $i = 0;
    $c = 0;
    for (; $i < $finalSize; $i++) {
        for ($c = 0; $c < $arraySize; $c++) {
            $output[$i][] = $array[$c][$i % $count[$c]];
        }
    }
    

    It is basically the same code but I used native functions when possible and also took out the loops some functionality that hadn't to be executed on each iteration.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里