Java:如何对3d数组的一部分进行排序?

时间:2015-03-31 21:52:42

标签: java arrays sorting

我有这个数组:array[2][7][2]

for (int i = 0; i < 2; i++) {
    for (int j = 0; j < 7; j++) {
        syso(array[i][j][0] + " ");
    }
    syso("/n");
}

目前上面的代码打印出来:

4 1 2 5 9 0 1

2 3 1 9 9 3 1

有没有办法以某种方式对这些进行排序?我并非真正关心array[i][j][1],只关注array[i][j][0]

我自己写了一个QuickSort函数,但很明显这段随机代码不起作用:

for (int i = 0; i < array.length; i++) {
    quickSort(array[i][0], 0, array[i].length - 1);     
}

编辑:

这里也是我的QuickSort功能:

static int partition(int a[], int l, int r) {
    int pivot = a[r];
    int k=l-1;

    for(int i=l; i <= r; i++) {
        if (a[i] <= pivot) {
            k++;

            int w = a[i];
            a[i] = a[k];
            a[k] = w;
        }
    }
    return k;
}

static void quickSort(int [] a, int l, int r) {
    if (l>=r) {
        return ;
    }

    int k = partition(a, l, r);
    quickSort(a, l, k-1);
    quickSort(a, k+1, r);
}

1 个答案:

答案 0 :(得分:1)

int[][] another = int[2][7];
for (int i = 0; i < array.length; i++) {
   for (int j = 0; j < array.length; j++) {
      anotner[i][j] = array[i][j][0];
   }
}
for (int[] a : anotner) {
    Arrays.sort(a);
}

然后使用anotner打印syso()