Arrays.sort를 사용하여 Java에서 2D 배열 정렬
자체 정렬을 구현하지 않고 값을 기반으로 2D 배열을 정렬하는 한 가지 방법 알고리즘은 오버로드된 Arrays#Sort(T[] a, Comparator c) 를 사용하는 것입니다. 메서드.
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]); } });
이 메서드는 Comparator를 두 번째 인수로 사용하므로 사용자가 자신만의 정렬 기준을 정의할 수 있습니다. 이 경우 우리가 제공한 비교기는 각 double[] 배열의 첫 번째 요소를 비교하고 0보다 작거나 크거나 같은지 여부를 나타내는 정수를 반환합니다.
Lambda 함수 사용 Java 8
Java 8에는 비교기를 정의하는 간결한 방법을 제공하는 람다 함수가 도입되었습니다. 다음과 같이 람다 함수를 사용하여 이전 코드를 다시 작성할 수 있습니다.
Arrays.sort(array, Comparator.comparingDouble(o -> o[0]));
이 람다 함수는 double[] 배열을 입력으로 사용하고 첫 번째 요소의 값을 double로 반환합니다. 이 비교기를 사용하여 배열을 정렬하면 원하는 결과를 얻을 수 있습니다.
위 내용은 Arrays.sort 및 비교기를 사용하여 Java에서 2D 배열을 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!