求一个数组,n个元素的不同组合(排列组合问题)

array('a1','b2','c3','d4','e5','x1','y1','z1');比如以上数组

我想要这个数组元素中三个元素的不同组合,例如下

array('a1','b2','c3');
array('a1','b2','d4');
array('a1','b2','e5');
array('a1','b2','x1');
array('a1','b2','y1');

方法一:最先想到的就是n次foreach循环,该方法简单粗暴

$data = array('a1','b2','c3','d4','e5','x1','y1','z1');

foreach ($data as $k_1 => $v_1) {
    foreach ($data as $k_2 => $v_2) {
        foreach ($data as $k_3 => $v_3) {
            if ($v_1 !== $v_2 && $v_1 !== $v_3 && $v_2 !== $v_3) {
                var_dump([$v_1,$v_2,$v_3]);
            }
        }    
    }
}
方法二:运用递归

<?php
$arr = array('a','b','c','d');
$result = array();
$t = getCombinationToString($arr, 3);
print_r($t);

function getCombinationToString($arr, $m) {
    if ($m ==1) {
        return $arr;
    }
    $result = array();

    $tmpArr = $arr;
    unset($tmpArr[0]);
    for($i=0;$i<count($arr);$i++) {
        $s = $arr[$i];
        $ret = getCombinationToString(array_values($tmpArr), ($m-1));

        foreach($ret as $row) {
            $result[] = $s . $row;
        }
    }

    return $result;
}
?>
结果如下:

Array
(
    [0] => abc
    [1] => abd
    [2] => acc
    [3] => acd
    [4] => adc
    [5] => add
    [6] => bbc
    [7] => bbd
    [8] => bcc
    [9] => bcd
    [10] => bdc
    [11] => bdd
    [12] => cbc
    [13] => cbd
    [14] => ccc
    [15] => ccd
    [16] => cdc
    [17] => cdd
    [18] => dbc
    [19] => dbd
    [20] => dcc
    [21] => dcd
    [22] => ddc
    [23] => ddd
)

文章出处:https://segmentfault.com/q/1010000005748820?_ea=890576

要实现n个数组排列组合,可以使用递归算法。 首先,我们定义一个函数,输入参数为n个数组一个空的结果列表。函数的作用是将n个数组进行排列组合,并将所有组合的结果保存在结果列表中。 然后,在函数中,我们使用两个循环嵌套来对数组进行排列组合。外层循环用于遍历数组的第一个元素,内层循环用于遍历其余n-1个数组的所有可能组合。 在内层循环中,我们将当前数组的第一个元素与剩余n-1个数组的所有可能组合拼接成新的组合,并递归调用函数。递归调用的参数为剩余的n-1个数组和拼接后的结果列表。 当递归调用的参数数组为空时,表示已经排列组合完成,将结果列表保存到最终的结果集中。 最后,返回最终的结果集。 下面是一个具体实现的示例代码: ```java import java.util.ArrayList; import java.util.List; public class PermutationCombination { public static void main(String[] args) { int[][] arrays = {{1, 2, 3}, {4, 5}, {6, 7, 8}}; List<List<Integer>> result = new ArrayList<>(); permutationCombination(arrays, new ArrayList<>(), result); System.out.println(result); } private static void permutationCombination(int[][] arrays, List<Integer> current, List<List<Integer>> result) { if (arrays.length == 0) { result.add(new ArrayList<>(current)); return; } for (int i = 0; i < arrays[0].length; i++) { current.add(arrays[0][i]); int[][] remaining = new int[arrays.length - 1][]; for (int j = 1; j < arrays.length; j++) { remaining[j - 1] = arrays[j]; } permutationCombination(remaining, current, result); current.remove(current.size() - 1); } } } ``` 运行上述代码,输出结果为: [[1, 4, 6], [1, 4, 7], [1, 4, 8], [1, 5, 6], [1, 5, 7], [1, 5, 8], [2, 4, 6], [2, 4, 7], [2, 4, 8], [2, 5, 6], [2, 5, 7], [2, 5, 8], [3, 4, 6], [3, 4, 7], [3, 4, 8], [3, 5, 6], [3, 5, 7], [3, 5, 8]] 以上代码实现了将3个数组进行排列组合的功能,你可以根据需要修改输入数组的个数来实现任意个数组排列组合
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值