1 回答
TA贡献1833条经验 获得超4个赞
您想要计算大小为 n 的数组中 r 元素的可能组合。你可以试试这个代码。我将该函数称为 nCr(不确定这是否是我们要解决的问题的正确数学符号)
public static void main(String[] args) {
String[] array2 = { "TST1", "TST2", "TST3"};
List<List<String>> l = new ArrayList<>();
for (var i: Arrays.asList(0, 1, 2, 3)) {
l.addAll(nCr(array2, i));
}
System.out.println(l);
}
private static List<List<String>> nCr(String[] array, int r) {
List<List<String>> result = new ArrayList<>();
if (r == 0) return result;
if (r == 1) return nC1(array);
for (int i = 0; i < array.length - r + 1; i++) {
List<List<String>> result2 = nCr(
Arrays.copyOfRange(array, i + 1, array.length),
r - 1);
for (var x: result2 ) {
x.add(array[i]);
result.add(x);
}
}
return result;
}
private static List<List<String>> nC1(String[] array) {
List<List<String>> l = new ArrayList<>();
for (var x: array) {
l.add(new ArrayList<>(Arrays.asList(x)));
}
return l;
}
输出:
[[TST1], [TST2], [TST3], [TST2, TST1], [TST3, TST1], [TST3, TST2], [TST3, TST2, TST1]]
添加回答
举报