Map先排序value小->大再排序key小->大,ArrayList与Stream分别实现

本文介绍了如何使用自定义比较器对Java Map进行排序,首先按照value从小到大排序,若value相等则按照key从小到大排序。提供了两种实现方式:传统ArrayList排序和Java 8 Stream API。示例代码详细展示了排序过程,最后对Stream API的使用进行了简单评价。
摘要由CSDN通过智能技术生成

一、题目

  对这个map进行排序,要求是先排序value小->大再排序key小->大(在value相等的情况)

结果:

 

我感觉思路主要是这个比较器,非常丝滑!!!

new Comparator<Map.Entry<String, Integer>>() {
            @Override
            public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
                     //当value相等的时候
                if (o1.getValue().equals(o2.getValue())) {
                     //按照key升序
                    return o1.getKey().compareTo(o2.getKey());
                }else {
                     //当value不相等的时候,按照value升序
                    return o1.getValue() - o2.getValue();
                }
            }
        }

二、解法

1.比较传统的解法:ArrayList

 其中有任何不懂的请到QQ群来问我,免费解答~~   QQ群在我收藏了最多的博文里的

   public static void main(String[] args) {
        Map<String, Integer> map = new HashMap<String, Integer>();
        map.put("d", 2);
        map.put("c", 1);
        map.put("b", 4);
        map.put("a", 3);
        map.put("f", 6);
        map.put("e", 6);

        List<Map.Entry<String, Integer>> infoIds = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());
        Collections.sort(infoIds,new Comparator<Map.Entry<String, Integer>>() {
            @Override
            public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {

                if (o1.getValue().equals(o2.getValue())) {
                    return o1.getKey().compareTo(o2.getKey());
                }else {
                    return o1.getValue() - o2.getValue();
                }
            }
        } );

        infoIds.forEach(o1 -> {
                    System.out.println(o1.getKey() +":" + o1.getValue());
                }
        );

2.JAVA8 新特性:Stram

  public static void main(String[] args) {
        Map<String, Integer> map = new HashMap<String, Integer>();
        map.put("d", 2);
        map.put("c", 1);
        map.put("b", 4);
        map.put("a", 3);
        map.put("f", 6);
        map.put("e", 6);


        HashMap<String, Integer> collect = map.entrySet().stream().sorted(new Comparator<Map.Entry<String, Integer>>() {
            @Override
            public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {

                if (o1.getValue().equals(o2.getValue())) {
                    return o1.getKey().compareTo(o2.getKey());
                }else {
                    return o1.getValue() - o2.getValue();
                }
            }//注意一定要用LinkedHashMap,否则打印出还是会乱序,只有LinkedHashMap会保留排序结果。用HashMap还是乱的。不信你可以试试
        }).collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue, (oldValue, newValue) -> oldValue, LinkedHashMap::new));

        collect.forEach((key, value) -> {
            System.out.println(key + ":" + value);
        });
        

三、总结

个人喜欢用stream感觉更加丝滑~  不用提前开一个空间去处理,到collect需要的时候再开空间,比较符合思考。而且之后还有对排序好的内容进行过滤之类操作挺方便!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值