亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

按值對地圖<鍵,值>進行排序

按值對地圖<鍵,值>進行排序

holdtom 2019-05-23 13:22:38
按值對地圖<鍵,值>進行排序我是Java的新手,經常發現我需要對Map<Key, Value>值進行排序。由于值不是唯一的,我發現自己將其轉換keySet為a array,并通過數組排序對該數組進行排序,并使用自定義比較器對與鍵關聯的值進行排序。有沒有更簡單的方法?
查看完整描述

3 回答

?
喵喔喔

TA貢獻1735條經驗 獲得超5個贊

這是一個通用友好版本:

public class MapUtil {
    public static <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
        List<Entry<K, V>> list = new ArrayList<>(map.entrySet());
        list.sort(Entry.comparingByValue());

        Map<K, V> result = new LinkedHashMap<>();
        for (Entry<K, V> entry : list) {
            result.put(entry.getKey(), entry.getValue());
        }

        return result;
    }}


查看完整回答
反對 回復 2019-05-23
?
HUX布斯

TA貢獻1876條經驗 獲得超6個贊

Java 8提供了一個新的答案:將條目轉換為流,并使用Map.Entry中的比較器組合器:


Stream<Map.Entry<K,V>> sorted =

    map.entrySet().stream()

       .sorted(Map.Entry.comparingByValue());

這將允許您使用按值的升序排序的條目。如果要降序值,只需反轉比較器:


Stream<Map.Entry<K,V>> sorted =

    map.entrySet().stream()

       .sorted(Collections.reverseOrder(Map.Entry.comparingByValue()));

如果值不具有可比性,則可以傳遞顯式比較器:


Stream<Map.Entry<K,V>> sorted =

    map.entrySet().stream()

       .sorted(Map.Entry.comparingByValue(comparator));

然后,您可以繼續使用其他流操作來使用數據。例如,如果您想要新地圖中的前10名:


Map<K,V> topTen =

    map.entrySet().stream()

       .sorted(Map.Entry.comparingByValue(Comparator.reverseOrder()))

       .limit(10)

       .collect(Collectors.toMap(

          Map.Entry::getKey, Map.Entry::getValue, (e1, e2) -> e1, LinkedHashMap::new));

或打印到System.out:


map.entrySet().stream()

   .sorted(Map.Entry.comparingByValue())

   .forEach(System.out::println);


查看完整回答
反對 回復 2019-05-23
  • 3 回答
  • 0 關注
  • 769 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號