web-dev-qa-db-fra.com

Java Classe de comparaison pour trier les tableaux

Disons, nous avons le tableau bidimensionnel suivant:

int camels[][] = new int[n][2];

Comment la classe Java Comparator doit être déclarée pour trier les tableaux par leurs premiers éléments dans l'ordre décroissant à l'aide de Arrays.sort(camels, comparator)? La fonction compare pour la référence est:

@Override public int compare(int[] a, int [] b)
{
    return b[0] - a[0];
}
31
Leonid

[...] Comment doit-on Java classe Comparateur être déclaré pour trier les tableaux par leur premiers éléments dans l'ordre décroissant [. ..]

Voici un exemple complet utilisant Java 8:

import Java.util.*;

public class Test {

    public static void main(String args[]) {

        int[][] twoDim = { {1, 2}, {3, 7}, {8, 9}, {4, 2}, {5, 3} };

        Arrays.sort(twoDim, Comparator.comparingInt(a -> a[0])
                                      .reversed());

        System.out.println(Arrays.deepToString(twoDim));
    }
}

Sortie:

[[8, 9], [5, 3], [4, 2], [3, 7], [1, 2]]

Pour Java 7 vous pouvez faire:

Arrays.sort(twoDim, new Comparator<int[]>() {
    @Override
    public int compare(int[] o1, int[] o2) {
        return Integer.compare(o2[0], o1[0]);
    }
});

Si vous avez la malchance de travailler sur Java 6 ou plus, vous feriez:

Arrays.sort(twoDim, new Comparator<int[]>() {
    @Override
    public int compare(int[] o1, int[] o2) {
        return ((Integer) o2[0]).compareTo(o1[0]);
    }
});
61
aioobe

La réponse de @aioobe est excellente. Je veux juste ajouter une autre façon pour Java 8.

int[][] twoDim = { { 1, 2 }, { 3, 7 }, { 8, 9 }, { 4, 2 }, { 5, 3 } };

Arrays.sort(twoDim, (int[] o1, int[] o2) -> o2[0] - o1[0]);

System.out.println(Arrays.deepToString(twoDim));

Pour moi, c'est intuitif et facile à retenir avec la syntaxe Java 8.

1
user2830451