>Java >java지도 시간 >PriorityQueue의 정렬 순서를 어떻게 사용자 정의할 수 있나요?

PriorityQueue의 정렬 순서를 어떻게 사용자 정의할 수 있나요?

Susan Sarandon
Susan Sarandon원래의
2024-12-13 08:40:10779검색

How Can I Customize the Sort Order of a PriorityQueue?

PriorityQueue에서 정렬 순서 사용자 정의

PriorityQueue는 요소의 정렬 순서를 유지하는 유용한 데이터 구조입니다. 기본적으로 요소의 자연스러운 순서를 기준으로 정렬됩니다. 이 순서를 사용자 정의하려면 비교기를 사용할 수 있습니다.

비교기 사용

PriorityQueue 생성자에는 비교기를 인수로 사용하는 오버로드가 있습니다. 이 비교기는 대기열의 정렬 기준을 정의합니다. 예를 들어 문자열을 길이에 따라 정렬하는 PriorityQueue를 생각해 보세요.

Comparator<String> comparator = new StringLengthComparator();
PriorityQueue<String> queue = new PriorityQueue<>(10, comparator);

Comparator 구현

StringLengthComparator 클래스는 Comparator 인터페이스를 구현합니다.

public class StringLengthComparator implements Comparator<String> {
    public int compare(String x, String y) {
        return x.length() - y.length();
    }
}

문자열 길이를 비교하여 비교기는 원하는 정렬을 설정합니다. order.

제안 및 추가

제안 및 추가 메소드 모두 대기열에 요소를 추가합니다. 그러나 요소가 성공적으로 추가되면 Offer는 true를 반환하고 대기열이 가득 차면 add는 예외를 발생시킵니다. 제한이 없는 PriorityQueue의 경우 두 메소드 사이에 기능적 차이가 없습니다.

위 내용은 PriorityQueue의 정렬 순서를 어떻게 사용자 정의할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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