문자열 키와 값이 포함된 맵이 주어지면 목표는 키를 오름차순으로 정렬하는 것입니다. 그런 다음 정렬된 키를 사용하여 두 개의 문자열을 생성합니다. 하나는 정렬된 질문을 포함하고 다른 하나는 해당 답변을 포함합니다.
키를 기준으로 지도를 정렬하려면 TreeMap을 활용하세요. , 이는 이러한 목적을 위해 특별히 설계되었습니다. Map 유형을 알 수 없는 경우 SortedSet 및 TreeSet을 사용하는 대체 방법을 사용할 수 있습니다.
SortedSet<String> keys = new TreeSet<>(map.keySet()); for (String key : keys) { String value = map.get(key); // Perform desired operations }
기술적으로 SortedMap을 구현하는 모든 클래스를 사용할 수 있습니다. 그러나 TreeMap이 가장 널리 사용되는 선택입니다. 더 복잡한 키 유형 또는 사용자 정의 정렬 요구 사항의 경우 다음 생성자를 사용하여 비교기를 제공하세요.
Comparator<Foo> comparator = (Foo o1, Foo o2) -> { // Define custom sort logic }; SortedSet<Foo> keys = new TreeSet<>(comparator); keys.addAll(map.keySet());
성능 고려 사항:
TreeMap과 TreeSet은 서로 다릅니다. HashMap 및 HashSet과 비교한 성능 특성. HashMap에서 O(1) 시간이 걸리는 조회 작업은 TreeMap에서 O(Log(N)) 시간이 필요합니다. 지도 크기가 커질수록 조회 시간도 늘어납니다.
위 내용은 Java 맵의 값을 키별로 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!