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

本文介绍了一种使用Java对Map<String,Integer>中的条目按照值进行降序排序的方法。通过将Map转换为List并利用自定义Comparator,实现了灵活的数据排序。此技术适用于需要对键值对集合进行排序的应用场景。

首先定义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();
        }
    }

Java 中对 `Map` 数据进行降序排序 10 条数据,可以先将 `Map` 的 `entrySet` 转换为 `List`,然后使用 `Collections.sort` 方法结合自定义的 `Comparator` 进行降序排序,最后截 10 条数据存放到 `LinkedHashMap` 中,因为 `LinkedHashMap` 可以保证插入顺序。以下是示例代码: ```java import java.util.*; public class MapSorting { public static <K, V extends Comparable<? super V>> Map<K, V> sortDescendAndTakeTop10(Map<K, V> map) { List<Map.Entry<K, V>> list = new ArrayList<>(map.entrySet()); Collections.sort(list, new Comparator<Map.Entry<K, V>>() { @Override public int compare(Map.Entry<K, V> o1, Map.Entry<K, V> o2) { return o2.getValue().compareTo(o1.getValue()); } }); Map<K, V> result = new LinkedHashMap<>(); int count = 0; for (Map.Entry<K, V> entry : list) { if (count >= 10) { break; } result.put(entry.getKey(), entry.getValue()); count++; } return result; } public static void main(String[] args) { Map<String, Integer> map = new HashMap<>(); map.put("设计与制作", 15); map.put("创作表现", 1326); map.put("基本元素", 10289); map.put("艺术作品", 898); map.put("理解与概念", 6); // 可以继续添加更多数据以测试 10 条 Map<String, Integer> sortedMap = sortDescendAndTakeTop10(map); System.out.println("降序排序 10 条数据后的结果: " + sortedMap); } } ``` 在上述代码中,`sortDescendAndTakeTop10` 方法实现了对 `Map` 进行降序排序 10 条数据的功能。在 `main` 方法中创建了一个示例 `Map`,并调用该方法进行测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值