gpt4 book ai didi

java - 获得数组幂集的最佳方法?

转载 作者:行者123 更新时间:2023-12-01 09:20:26 26 4
gpt4 key购买 nike

获取数组幂集的最佳方法是什么?例如,如果我有一个数组:

int[] A = {1, 2}

并获得以下输出

int[] P = {{}, {1}, {2}, {1, 2}}

最佳答案

试试这个。

int[] a = {1, 2};
int max = 1 << a.length;
int[][] result = new int[max][];
for (int i = 0; i < max; ++i) {
result[i] = new int[Integer.bitCount(i)];
for (int j = 0, b = i, k = 0; j < a.length; ++j, b >>= 1)
if ((b & 1) != 0)
result[i][k++] = a[j];
}
System.out.println(Arrays.deepToString(result));

结果:

[[], [1], [2], [1, 2]]

关于java - 获得数组幂集的最佳方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40201309/

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