>  기사  >  Java  >  Arrays.sort 및 비교기를 사용하여 Java에서 2D 배열을 정렬하는 방법은 무엇입니까?

Arrays.sort 및 비교기를 사용하여 Java에서 2D 배열을 정렬하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-11 09:34:03156검색

How to Sort a 2D Array in Java Using Arrays.sort and Comparators?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.