給定一個包含字串鍵和值的映射,目標是按升序對鍵進行排序。然後,排序後的鍵將用於建立兩個字串:一個包含排序後的問題,另一個包含相應的答案。
要按鍵對 Map 進行排序,請使用 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中文網其他相關文章!