Arrays.sort를 사용하여 2D 배열 정렬
다차원 배열을 정렬하는 것은 복잡한 작업이 될 수 있습니다. 그러나 Java의 Arrays.sort 메소드를 사용하면 이를 효율적으로 달성할 수 있습니다.
구체적으로 이 솔루션에는 Comparator를 다음과 같이 사용하는 오버로드된 Arrays#Sort(T[] a, Comparator c) 메소드를 사용하는 것이 포함됩니다. 두 번째 주장입니다. 비교기는 객체를 비교하는 방법을 정의하는 객체입니다. 이 경우 각 하위 배열의 첫 번째 요소 값을 비교하려고 합니다.
이를 구현하려면 java.util.Comparator 인터페이스를 구현하고 해당 Compare() 메서드를 재정의하는 비교기를 생성합니다. 이 메서드는 두 배열의 첫 번째 요소를 비교하고 표시되는 순서에 따라 -1, 0 또는 1을 반환해야 합니다.
예를 들어 다음 2D 배열을 고려해 보세요.
double[][] myArr = { {1, 5}, {13, 1.55}, {12, 100.6}, {12.1, .85} };
이 배열을 각 하위 배열의 첫 번째 요소 값을 기준으로 오름차순으로 정렬하려면 다음 코드를 사용하세요.
java.util.Arrays.sort(myArr, new java.util.Comparator<double[]>() { public int compare(double[] a, double[] b) { return Double.compare(a[0], b[0]); } });
이렇게 하면 다음과 같은 정렬된 배열이 생성됩니다.
[ {1, 5}, {12, 100.6}, {12.1, .85}, {13, 1.55} ]
Java 8 이상에서는 람다를 사용하여 비교기를 단순화할 수 있습니다.
Arrays.sort(array, Comparator.comparingDouble(o -> o[0]));
위 내용은 Arrays.sort를 사용하여 Java에서 2D 배열을 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!