我想用PHP列出单个数组中所有可能的组合

时间:2013-11-11 09:22:03

标签: php arrays foreach combinations

这是来自" How can I list all possible combinations?"的扩展问题。对于最后一个问题,它显示了所有排列而不是所有组合。

$num_array2 = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

foreach($num_array2 AS $value1) {
    foreach($num_array2 AS $value2) {
        if($value2 == $value1) {
            continue;
        }
        foreach($num_array2 AS $value3) {
            if($value3 == $value1 || $value3 == $value2) {
                continue;
            }
            foreach($num_array2 AS $value4) {
                if($value4 == $value1 || $value4 == $value2 || $value4 == $value3) {
                    continue;
                }
                foreach($num_array2 AS $value5) {
                    if($value5 == $value1 || $value5 == $value2 || $value5 == $value3 || $value5 == $value4) {
                        continue;
                    }
                    foreach($num_array2 AS $value6) {
                        if($value6 == $value1 || $value6 == $value2 || $value6 == $value3 || $value6 == $value4 || $value6 == $value5) {
                            continue;
                        }
                        echo "$value1, $value2, $value3, $value4, $value5, $value6 \n<br />";
                    }
                }
            }
        }
    }
}

结果将是:

1, 2, 3, 4, 5, 6 
1, 2, 3, 4, 5, 7 
1, 2, 3, 4, 5, 8 
1, 2, 3, 4, 5, 9 
1, 2, 3, 4, 5, 10 
1, 2, 3, 4, 6, 5 
1, 2, 3, 4, 6, 7 
1, 2, 3, 4, 6, 8 
1, 2, 3, 4, 6, 9 
1, 2, 3, 4, 6, 10 

如您所见&#34; 1,2,3,4,5,6&#34;和&#34; 1,2,3,4,6,5和#34;重复(虽然它不是相同的顺序)。我不希望结果像&#34; 1,2,3,4,6,5和#34;要显示。我该如何修改代码?

1 个答案:

答案 0 :(得分:1)

通过升级忽略代码问题,您的问题在于您只是将输出限制为不重复数字。但是,您需要一个更强的约束:不要对两个不同的输出进行相同的选择,

更简单的方法是跟踪您已选择的数组位置:只要 num_array2 ,请考虑一个位数组,此数组表示一个选择,因此如果您采取了一个位置,< strong>我 num_array2 ,那么你的位数组应该在该位置包含1。

然后,您可以将您的位数组存储在一组“选择签名”中,并为每个可能的输出检查其选择签名是否已在该组中。

这是一个相当简单而愚蠢的解决方案,但我认为它可以帮助您理解您的问题。