>Java >java지도 시간 >Arrays.sort를 사용하여 Java에서 2D 배열을 정렬하는 방법은 무엇입니까?

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

Patricia Arquette
Patricia Arquette원래의
2024-11-13 01:40:02982검색

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

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

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