zoukankan      html  css  js  c++  java
  • TreeMap升序|降序排列和按照value进行排序

    TreeMap 升序|降序排列

    import java.util.Comparator;
    import java.util.TreeMap;
    public class Main {
        public static void main(String[] args) {
            TreeMap<Integer,Integer> map1 = new TreeMap<Integer,Integer>();  //默认的TreeMap升序排列
            TreeMap<Integer,Integer> map2= new TreeMap<Integer,Integer>(new Comparator<Integer>(){
                 /* 
                 * int compare(Object o1, Object o2) 返回一个基本类型的整型, 
                 * 返回负数表示:o1 小于o2, 
                 * 返回0 表示:o1和o2相等, 
                 * 返回正数表示:o1大于o2。 
                 */  
                public int compare(Integer a,Integer b){
                    return b-a;            
                }
                });
            map2.put(1,2);
            map2.put(2,4);
            map2.put(7, 1);
            map2.put(5,2);
            System.out.println("Map2="+map2);  
            
            map1.put(1,2);
            map1.put(2,4);
            map1.put(7, 1);
            map1.put(5,2);
            System.out.println("map1="+map1);
        }
    }

    TreeMap按照value进行排序

    TreeMap底层是根据红黑树的数据结构构建的,默认是根据key的自然排序来组织(比如integer的大小,String的字典排序)。所以,TreeMap只能根据key来排序,是不能根据value来排序的(否则key来排序根本就不能形成TreeMap)。

    今天有个需求,就是要根据treeMap中的value排序。所以网上看了一下,大致的思路是把TreeMap的EntrySet转换成list,然后使用Collections.sor排序。代码:

    public static void sortByValue() {
            Map<String,String> map = new TreeMap<String,String>();
            map.put("a", "dddd");
            map.put("d", "aaaa");
            map.put("b", "cccc");
            map.put("c", "bbbb");
            
            List<Entry<String, String>> list = new ArrayList<Entry<String, String>>(map.entrySet());
            
            Collections.sort(list,new Comparator<Map.Entry<String,String>>() {
                //升序排序
                public int compare(Entry<String, String> o1, Entry<String, String> o2) {
                    return o1.getValue().compareTo(o2.getValue());
                }
            });
            
            for (Entry<String, String> e: list) {
                System.out.println(e.getKey()+":"+e.getValue());
            }
        }
  • 相关阅读:
    Freemarker中JS取Data-model的值的问题
    Jquery动态添加元素并给元素增加onchange相应
    [算法] 动态规划
    Linux安装mysql.8.0.12
    Linux命令
    [算法] 并查集
    Flume整合Kafka完成实时数据采集
    Kafka 单节点部署
    Spark Streaming——Flume实例
    Spark实战——日志分析
  • 原文地址:https://www.cnblogs.com/shamo89/p/9885779.html
Copyright © 2011-2022 走看看