我有这个数组: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);
}
答案 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()
。