> Java > java지도 시간 > Java 맵의 값을 키별로 정렬하는 방법은 무엇입니까?

Java 맵의 값을 키별로 정렬하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-25 09:38:13
원래의
913명이 탐색했습니다.

How to Sort a Java Map's Values by its Keys?

Java에서 키별로 맵 값을 정렬하는 방법

Java에서 키별로 맵을 정렬하는 것은 데이터를 구성하고 검색하는 데 필수적입니다. 효율적으로. 이 가이드는 이 작업에 접근하는 방법에 중점을 두고 다양한 지도 유형에 대한 솔루션을 제공합니다.

자연 순서를 위한 TreeMap 사용

자동 키 정렬이 필요한 시나리오의 경우 , TreeMap은 이상적인 솔루션입니다. 요소를 자연스럽게 정렬된 순서로 유지합니다. 즉, 키가 사전순으로 정렬됩니다. 예는 다음과 같습니다.

TreeMap<String, String> questions = new TreeMap<>();
questions.put("question1", "1");
questions.put("question9", "1");
questions.put("question2", "4");
questions.put("question5", "2");

// Iterate over the sorted keys and get the values
for (Map.Entry<String, String> entry : questions.entrySet()) {
    System.out.println(entry.getKey() + ": " + entry.getValue());
}
로그인 후 복사

사용자 정의 비교기를 사용하여 맵 키 정렬

지도의 키가 Comparable을 구현하지 않는 사용자 정의 개체인 경우 다음을 수행할 수 있습니다. 사용자 정의 비교기를 사용하여 키 정렬 방법을 지정합니다. TreeMap 또는 TreeSet을 사용하면 초기화 중에 비교기를 제공할 수 있습니다.

// Define a custom comparator
Comparator<MyObject> comparator = new MyObjectComparator();

// Create a sorted map using the comparator
TreeMap<MyObject, String> sortedMap = new TreeMap<>(comparator);

// Add objects to the map
sortedMap.put(new MyObject("Object1"), "Value1");
sortedMap.put(new MyObject("Object3"), "Value3");
sortedMap.put(new MyObject("Object2"), "Value2");
로그인 후 복사

TreeSet을 사용하여 맵 정렬

또 다른 접근 방식은 TreeSet을 사용하는 것입니다. 해당 요소에 대한 오름차순을 제공합니다. 여기에는 맵의 키에서 TreeSet을 생성한 다음 정렬된 키를 반복하여 해당 값을 검색하는 작업이 포함됩니다.

SortedSet<String> keys = new TreeSet<>(map.keySet());
for (String key : keys) {
    System.out.println(key + ": " + map.get(key));
}
로그인 후 복사

성능에 대한 참고 사항

Java의 경우 , 정렬을 위해 TreeMap 또는 TreeSet을 사용하면 알고리즘 상충관계가 발생합니다. HashMap 또는 HashSet의 일정한 시간 복잡도(O(1)) 작업 대신 키 조회 또는 삽입과 같은 작업은 정렬된 데이터 구조에서 O(Log(N)) 작업이 됩니다. 이는 요소 수가 증가함에 따라 이러한 작업에 필요한 시간이 증가한다는 것을 의미합니다.

위 내용은 Java 맵의 값을 키별로 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿