1. ホーム
  2. java

[解決済み】 java Arrays.sort 2d array

2022-02-22 23:40:01

質問

次の配列を[][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

自分でソートを実装することなく、これを実現したいと考えています。

どのように解決するのですか?

オーバーロードを使用する Arrays#Sort(T[] a, Comparator c) で、第2引数に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です。 このような大きなコンパレータの代わりに、ラムダ関数を使うことができます。

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