gpt4 book ai didi

java - 返回 Java 矩阵中的所有组合

转载 作者:行者123 更新时间:2023-12-02 03:08:04 25 4
gpt4 key购买 nike

我见过这个问题的不同版本,但从来没有一个好的答案。我有一个 MXN 数组,想要返回 M 大小的所有可能组合。我给你举个例子,有一个3X3的数组。结果应该是 27 种组合。我在这里尝试递归方法,但到目前为止还没有运气。

最佳答案

请尝试一下这个程序是否可以帮助您。我用过这个矩阵

   int[][] matrix = {{1, 2, 3},
{4, 5, 6},
{7, 8, 9}};

输出为 27 种组合,如下所示。

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class Main {
private static List<int[]> combine(int[][] matrix) {
int sizeArray[] = new int[matrix.length];
int counterArray[] = new int[matrix.length];
int total = 1;
for (int i = 0; i < matrix.length; ++i) {
sizeArray[i] = matrix[i].length;
total *= matrix[i].length;
}
List<int[]> list = new ArrayList<>(total);
StringBuilder sb;
for (int count = total; count > 0; --count) {
sb = new StringBuilder();
for (int i = 0; i < matrix.length; ++i) {
sb.append(matrix[i][counterArray[i]]);
}
int tmpi[] = new int[sb.toString().length()];
for (int tmp = 0; tmp < sb.toString().length(); tmp++) {
tmpi[tmp] = Integer.parseInt("" + sb.toString().toCharArray()[tmp]);
}
list.add(tmpi);
for (int incIndex = matrix.length - 1; incIndex >= 0; --incIndex) {
if (counterArray[incIndex] + 1 < sizeArray[incIndex]) {
++counterArray[incIndex];
break;
}
counterArray[incIndex] = 0;
}
}
return list;
}

public static void main(String[] args) {
int[][] matrix = {{1, 2, 3},
{4, 5, 6},
{7, 8, 9}};
int i = 0;
for (int[] c : (combine(matrix))) {
System.out.println(Arrays.toString(c));
i++;
}
System.out.println(i);
}
}

测试

[1, 4, 7]
[1, 4, 8]
[1, 4, 9]
[1, 5, 7]
[1, 5, 8]
[1, 5, 9]
[1, 6, 7]
[1, 6, 8]
[1, 6, 9]
[2, 4, 7]
[2, 4, 8]
[2, 4, 9]
[2, 5, 7]
[2, 5, 8]
[2, 5, 9]
[2, 6, 7]
[2, 6, 8]
[2, 6, 9]
[3, 4, 7]
[3, 4, 8]
[3, 4, 9]
[3, 5, 7]
[3, 5, 8]
[3, 5, 9]
[3, 6, 7]
[3, 6, 8]
[3, 6, 9]
27

关于java - 返回 Java 矩阵中的所有组合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41453353/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com