1

我有以下代码:

static boolean nextPerm(int[] A) {
        int N = A.length;
        int k = N - 1;
        int[] S = { };
        while (k >= 0) {
            if (S.length > 0 && containsLarger(S, A[k])) {
                int v = firstLargest(S, A[k]);
                //int vIndex = Arrays.asList(S).indexOf(v);
                List<Integer> test = Arrays.asList(S); // // ERRORS HERE. Before error, S is { 2 } 
                System.out.println(test.get(0)); 
                int vIndex = test.indexOf(S);
                S[vIndex] = A[k];
                A[k] = v;
                System.arraycopy(S, 0, A, k + 1, N - k);
                return true;
            } else {
                S = addIntAscend(S, A[k]);
                k -= 1;
            }
        }
        return false;
    }

在错误之前,S 是一个 int 数组 { 2 }。当我将 TEST 设置为 Arrays.asList(S) 时出错:

Perms.java:44: error: incompatible types
                List<Integer> test = Arrays.asList(S);
                                                  ^
  required: List<Integer>
  found:    List<int[]>
1 error

为什么会这样?我以为原语是自动装箱的?

4

2 回答 2

4

看看这个被关闭的错误报告Not an Issue,理由如下。

整个数组的自动装箱不是指定的行为,这是有充分理由的。对于大型阵列来说,它可能非常昂贵。

因此,要将数组转换为列表,您需要这样做

List<Integer> test = new ArrayList<Integer>(S.length);
for (int i : S) {
    test.add(i);
}
于 2013-10-09T08:06:33.193 回答
3

基元是自动装箱的,但数组不是。如果您将 int[] 更改为 Integer[],它将起作用

于 2013-10-09T08:04:25.880 回答