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 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值