• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php 从m个数中取n个数组合,超出内存怎么办?

php 搞代码 4年前 (2022-01-25) 33次浏览 已收录 0个评论
文章目录[隐藏]

下面是我网上找到的代码:

<code>function getCombinationToString($arr,$m){    $result = array();    if ($m ==1)    {        return $arr;    }    if ($m == count($arr))    {        $result[] = implode(',' , $arr);        return $result;    }    $temp_firstelement = $arr[0];    unset($arr[0]);    $arr = array_values($arr);    $temp_list1 = getCombinationToString($arr, ($m-1));    foreach ($temp_list1 as $s)    {        $s = $temp_firstelement.','.$s;        $result[] = $s;    }    unset($temp_list1);    $temp_list2 = getCombinationToString($arr, $m);    foreach ($temp_list2 as $s)    {        $result[] = $s;    }    unset($temp_list2);    return $result;}</code>
<code>$arr=['a','b','c','d','e','f'];getCombinationToString($arr,3);</code>

输出结果:

Array
(

<code>[0] => a,b,c[1] => a,b,d[2] => a,b,e[3] => a,b,f[4] => a,c,d[5] => a,c,e[6] => a,c,f[7] => a,d,e[8] => a,d,f[9] => a,e,f[10] => b,c,d[11] => b,c,e[12] => b,c,f[13] => b,d,e[14] => b,d,f[15] => b,e,f[16] => c,d,e[17] => c,d,f[18] => c,e,f[19] => d,e,f</code>

)
现在我的$arr有几百个元素,执行后超出内存,请问该怎么办?有没有人能帮忙改进下组合的函数,我这方面很弱,不知道怎么做?

回复内容:

*本文来源gaodai#ma#com搞@代~码^网+搞代gaodaima码

下面是我网上找到的代码:

<code>function getCombinationToString($arr,$m){    $result = array();    if ($m ==1)    {        return $arr;    }    if ($m == count($arr))    {        $result[] = implode(',' , $arr);        return $result;    }    $temp_firstelement = $arr[0];    unset($arr[0]);    $arr = array_values($arr);    $temp_list1 = getCombinationToString($arr, ($m-1));    foreach ($temp_list1 as $s)    {        $s = $temp_firstelement.','.$s;        $result[] = $s;    }    unset($temp_list1);    $temp_list2 = getCombinationToString($arr, $m);    foreach ($temp_list2 as $s)    {        $result[] = $s;    }    unset($temp_list2);    return $result;}</code>
<code>$arr=['a','b','c','d','e','f'];getCombinationToString($arr,3);</code>

输出结果:

Array
(

<code>[0] => a,b,c[1] => a,b,d[2] => a,b,e[3] => a,b,f[4] => a,c,d[5] => a,c,e[6] => a,c,f[7] => a,d,e[8] => a,d,f[9] => a,e,f[10] => b,c,d[11] => b,c,e[12] => b,c,f[13] => b,d,e[14] => b,d,f[15] => b,e,f[16] => c,d,e[17] => c,d,f[18] => c,e,f[19] => d,e,f</code>

)
现在我的$arr有几百个元素,执行后超出内存,请问该怎么办?有没有人能帮忙改进下组合的函数,我这方面很弱,不知道怎么做?

那就不要存啊,生成一个输出一个便可以了


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php 从m个数中取n个数组合,超出内存怎么办?

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址