首頁 > Java > java教程 > 如何按鍵對 Java 映射的值進行排序?

如何按鍵對 Java 映射的值進行排序?

Barbara Streisand
發布: 2024-12-30 12:15:14
原創
707 人瀏覽過

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

在 Java 中按鍵對映射值進行排序

給定一個包含字串鍵和值的映射,目標是按升序對鍵進行排序。然後,排序後的鍵將用於建立兩個字串:一個包含排序後的問題,另一個包含相應的答案。

簡短答案

要按鍵對 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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板