>Java >java지도 시간 >## 제거하고 다시 삽입하지 않고도 Java PriorityQueue의 우선순위를 업데이트할 수 있나요?

## 제거하고 다시 삽입하지 않고도 Java PriorityQueue의 우선순위를 업데이트할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2024-10-25 08:05:02300검색

## Can You Update Priorities in a Java PriorityQueue Without Removing and Re-Inserting?

Java PriorityQueues에서 우선순위 업데이트

객체 순서 지정을 위해 Comparator와 함께 PriorityQueue를 활용하는 경우 객체의 클래스 변수에 대한 후속 변경 사항(다음에 따라) 어떤 우선순위가 계산되는지) 문제가 발생합니다.

전통적으로 간단한 해결 방법은 객체를 제거하고 해당 값을 업데이트한 후 다시 삽입하여 우선순위 큐의 비교기를 트리거하는 것입니다. 그러나 PriorityQueue 주위에 래퍼 클래스를 만드는 것보다 더 효율적인 대안이 있습니까?

답변

불행히도 제거하고 다시 삽입하는 것이 가장 효과적인 접근 방식으로 남아 있습니다. PriorityQueues는 본질적으로 삽입 시 적절한 위치에 새 요소를 삽입하여 대기열 성능을 최적화합니다. 대기열 제거 작업 중에 우선순위가 가장 높은 요소를 검색하면 성능에 큰 영향을 미칠 수 있습니다.

TreeMap은 HashMap(요소 해시 코드가 변경되면 실패함)과 함께 이 제한 사항을 공유합니다.

래퍼 클래스를 생성하려면 다음이 필요할 수 있습니다. 비교 코드를 대기열에 추가에서 제거로 이동하여 대기열에 추가하는 동안 정렬할 필요가 없습니다. 그러나 이 접근 방식은 성능을 저하시키며 우선순위 업데이트 시 동기화가 필요합니다. 어느 쪽이든 동기화가 필요하므로 대기열에서 제거 및 다시 대기열에 추가하는 것이 더 간단하고 성능이 뛰어난 솔루션을 제공합니다.

위 내용은 ## 제거하고 다시 삽입하지 않고도 Java PriorityQueue의 우선순위를 업데이트할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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