-2

这是“如何列出所有可能的组合? ”的扩展问题。对于最后一个问题,它显示了所有排列而不是所有组合。

$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 

如您所见,重复了“1、2、3、4、5、6”和“1、2、3、4、6、5”(尽管顺序不同)。我不希望显示像“1、2、3、4、6、5”这样的结果。我应该如何修改代码?

4

1 回答 1

1

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

更简单的方法是跟踪您已经选择了哪个数组位置:考虑一个与num_array2一样长的位数组,这个数组表示一个选择,因此如果您已经采取了一个位置,inum_array2那么您的位数组应该包含一个 1在那个位置。

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

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

于 2013-11-11T09:35:17.270 回答