java Arrays.sort 2d array

2022-08-31 10:57:52

我希望根据[][0]的值对以下数组进行排序

double[][] myArr = new double[mySize][2];

例如,myArr的内容是:

1      5
13     1.55
12     100.6
12.1   .85

我希望它能达到:

1      5
12     100.6
12.1   .85
13     1.55

我希望做到这一点,而不必实现我自己的排序。


答案 1

使用重载数组#Sort(T[] a, Comparator c),它将 Comparator 作为第二个参数。

double[][] array= {
{1, 5},
{13, 1.55},
{12, 100.6},
{12.1, .85} };

java.util.Arrays.sort(array, new java.util.Comparator<double[]>() {
    public int compare(double[] a, double[] b) {
        return Double.compare(a[0], b[0]);
    }
});

JAVA-8:我们可以使用 lambda 函数,而不是那个大的比较器,如下所示-

Arrays.sort(array, Comparator.comparingDouble(o -> o[0]));

答案 2

欢迎 Java 8:

Arrays.sort(myArr, (a, b) -> Double.compare(a[0], b[0]));