> 백엔드 개발 > PHP 튜토리얼 > 求助一个数组元素所有组合的算法

求助一个数组元素所有组合的算法

WBOY
풀어 주다: 2016-06-23 14:24:05
원래의
1400명이 탐색했습니다.

向高手们求助一个算法

有数组:
$arr=array(A,B,C);
要求输出:
A
AB
AC
ABC
B
BA
BC
C
CA
CB

就是要输出数组元素的所有组合,顺序不要求,只要求能全部输入就可以了


回复讨论(解决方案)

上面还要输出一个ACB,BAC,BCA,CAB,CBA

也就是
Array ( [0] => A [1] => AB [2] => AC [3] => ABC [4] => ACB [5] => B [6] => BA [7] => BC [8] => BAC [9] => BCA [10] => C [11] => CA [12] => CB [13] => CBA [14] => CAB ) 

迪尔卡积又来了?请查看精华区

$ar = array('A', 'B', 'C');$res = array_chunk($ar, 1);for($i=1; $i<count($ar); $i++) {  foreach($res as $r) {    if(count($r) != $i) continue;    foreach($ar as $v) {      if(! in_array($v, $r)) $res[] = array_merge($r, array($v));    }  }}//print_r($res);foreach($res as &$r) $r = join('', $r);print_r($res);
로그인 후 복사
Array
(
[0] => A
[1] => B
[2] => C
[3] => AB
[4] => AC
[5] => BA
[6] => BC
[7] => CA
[8] => CB
[9] => ABC
[10] => ACB
[11] => BAC
[12] => BCA
[13] => CAB
[14] => CBA
)

<?php$ar=array(A,B,C);function foo($ar,$m,$s='') {global $global_arr;//命名全局变量if (!empty($s)) $global_arr[]=$s;if($m > 0) { for($i=0;$i<count($ar);$i++) { if (!strstr($s,$ar[$i])) foo($ar,$m-1,$s.$ar[$i]); //递归    }  }}foo($ar,count($ar));print_r($global_arr);//输出结果?>
로그인 후 복사

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿