Ответ 1
[...] Как должен быть объявлен класс Java Comparator для сортировки массивов по первым элементам в порядке убывания [...]
Вот полный пример использования 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));
}
}
Выход:
[[8, 9], [5, 3], [4, 2], [3, 7], [1, 2]]
Для Java 7 вы можете сделать:
Arrays.sort(twoDim, new Comparator<int[]>() {
@Override
public int compare(int[] o1, int[] o2) {
return Integer.compare(o2[0], o1[0]);
}
});
Если вам не повезло работать на Java 6 или старше, вы должны сделать:
Arrays.sort(twoDim, new Comparator<int[]>() {
@Override
public int compare(int[] o1, int[] o2) {
return ((Integer) o2[0]).compareTo(o1[0]);
}
});