[英]Nested sorting 2d array java
我有一個8列(col0-col7)和一千行的2D數組,我想對2列進行升序排序:col2和col3。 我想優先考慮col2列,並對該列進行優先排序。 如果col2中的兩個值相等(很有可能),那么我想基於col3進行排序。 這是我使用的當前代碼:
public static void sortMyArray() {
Arrays.sort(myArray, new Comparator<double[]>() {
public int compare(double[] a, double[] b) {
int result = Double.compare(a[2], b[2]);
if (result == 0) {
return Double.compare(a[3], b[3]);
} else {
return result;
}
}
});
}
我使用的當前代碼僅在col3上對數組進行排序。 由於以后的計算,我想堅持使用二維數組。
希望你能幫助我。
編輯:根據用戶的反饋進行了一些更改(對此非常感謝!)。 但是,問題仍然存在。 這是我用來測試代碼段的代碼:
public static void loadTotalData() {
for (int i = 0; i < myArray.length; i++) {
myArray[i][0] = classOriginal.allData[i].col0data;
myArray[i][1] = classOriginal.allData[i].col1data;
myArray[i][2] = classOriginal.allData[i].col2data;
myArray[i][3] = classOriginal.allData[i].col3data;
myArray[i][4] = 0.0;
myArray[i][5] = 0.0;
myArray[i][6] = 0.0;
myArray[i][7] = 0.0;
}
System.out.println(myArray[0][3]);
System.out.println(myArray[1][3]);
System.out.println(myArray[2][3]);
System.out.println(myArray[3][3]);
System.out.println(myArray[4][3]);
System.out.println(myArray[5][3]);
System.out.println(myArray[6][3]);
System.out.println(myArray[7][3]);
System.out.println(myArray[8][3]);
System.out.println(myArray[9][3]);
System.out.println(myArray[10][3]);
classForSortingAndLoading.sortMyArray();
System.out.println(myArray[0][3]);
System.out.println(myArray[1][3]);
System.out.println(myArray[2][3]);
System.out.println(myArray[3][3]);
System.out.println(myArray[4][3]);
System.out.println(myArray[5][3]);
System.out.println(myArray[6][3]);
System.out.println(myArray[7][3]);
System.out.println(myArray[8][3]);
System.out.println(myArray[9][3]);
System.out.println(myArray[10][3]);
可能不是測試此問題的最有效方法,但是我知道數據源,因此知道在排序前后應該返回的內容。
您應該比較a
和b
列,而不是a
和a
:
public static void sortMyArray() {
Arrays.sort(myArray, new Comparator<double[]>() {
public int compare(double[] a, double[] b) {
int result = Double.compare(a[2], b[2]);
if (result == 0) {
return Double.compare(a[3], b[3]);
} else {
return result;
}
}
});
}
由於a[2]
在定義(身份)上等於a[2]
, result
始終為0
,因此只比較了列3,而列3始終將返回0
(從不執行條件的return results
分支)。
例:
public class Main {
public static void main(String[] args) {
double[][] myArray = sortMyArray();
printArray(myArray);
}
public static double[][] sortMyArray() {
double[][] myArray = new double[][] {
{1, 11, 21, 37, 41, 51, 61},
{0, 10, 20, 30, 40, 50, 60},
{2, 12, 22, 32, 42, 52, 62},
{1, 11, 21, 31, 41, 51, 61},
};
Arrays.sort(myArray, new Comparator<double[]>() {
public int compare(double[] a, double[] b) {
int result = Double.compare(a[2], b[2]);
if (result == 0) {
return Double.compare(a[3], b[3]);
} else {
return result;
}
}
});
return myArray;
}
private static void printArray(double[][] myArray) {
for(int row = 0; row < myArray.length; row++){
for( int column = 0; column < myArray[0].length; column++){
System.out.print(myArray[row][column] + " ");
}
System.out.println();
}
}
}
執行此代碼將產生以下輸出:
0.0 10.0 20.0 30.0 40.0 50.0 60.0
1.0 11.0 21.0 31.0 41.0 51.0 61.0
1.0 11.0 21.0 37.0 41.0 51.0 61.0
2.0 12.0 22.0 32.0 42.0 52.0 62.0
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.