map如何进行排序,并且取排序后的前三数据

首先定义Map并且赋值。

Map<String, Integer> map = new HashMap<String, Integer>();

        map.put("a", 2);
        map.put("b", 4);
        map.put("c", 1);
        map.put("d", 5);
        map.put("e", 3);

/*

  • Collections.sort(list, new PriceComparator())

    • 参数一:需要排序的list
    • 参数二:比较器,实现Comparator接口的类,返回一个int型的值,就相当于一个标志,告诉sort方法按什么顺序来对list进行排序。
  • Comparator是个接口,可重写compare()及equals()这两个方法,用于比较功能;如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g这样,当然数字也是这样的。

    • compare(a,b)方法:根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。
    • equals(obj)方法:仅当指定的对象也是一个 Comparator,并且强行实施与此 Comparator 相同的排序时才返回 true。

*/

定义一个list,并且把map存进去

        List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>();
        list.addAll(map.entrySet());

        Collections.sort(list, new ValueComparator());//将map排序完成以后重新存入list中

//输出  

for (Map.Entry<String, Integer> entry : list) {

            System.out.println(entry.getValue()+"-------"+entry.getKey());
        }

//排序

private static class ValueComparator implements Comparator<Map.Entry<String, Integer>> {

        @Override
        public int compare(Entry<String, Integer> entry1, Entry<String, Integer> entry2) {
            return entry2.getValue() - entry1.getValue();
        }
    }

阅读更多
换一批

没有更多推荐了,返回首页