zoukankan      html  css  js  c++  java
  • map根据属性排序、取出map前n个

        /**
         * map根据value排序
         * flag = 1 正序
         * flag = 0 倒序
         *
         * @param map
         * @param flag
         * @return
         */
        public static <K, V extends Comparable<? super V>> LinkedHashMap<K, V> sortByValue(Map<K, V> map, int flag) {
            LinkedHashMap<K, V> sortMap = new LinkedHashMap<>();
            if (flag == 1) {
                map.entrySet().stream().sorted(Comparator.comparing(Map.Entry::getValue)).forEach(entry -> sortMap.put(entry.getKey(), entry.getValue()));
            } else {
                map.entrySet().stream().sorted((o1, o2) -> o2.getValue().compareTo(o1.getValue())).forEach(entry -> sortMap.put(entry.getKey(), entry.getValue()));
            }
            return sortMap;
        }
    
        /**
         * 取出map前n个
         *
         * @param map
         * @param length
         * @return
         */
        @Override
        public LinkedHashMap<String, Double> subMap(LinkedHashMap<String, Double> map, int length) {
            List<Map.Entry<String, Double>> lists = new ArrayList<>(map.entrySet());
            LinkedHashMap<String, Double> sortedMap = new LinkedHashMap<>();
            if (lists.size() >= length) {
                for (Map.Entry<String, Double> set : lists.subList(0, length)) {
                    sortedMap.put(set.getKey(), set.getValue());
                }
            } else {
                for (Map.Entry<String, Double> set : lists) {
                    sortedMap.put(set.getKey(), set.getValue());
                }
            }
            return sortedMap;
        }
    

      

  • 相关阅读:
    IP地址加时间戳加3位随机数
    你会想造一艘船吗?
    提问的智慧
    建造者模式
    设计模式(一)
    jeesite中activiti中的流程表梳理
    如何读书、学习?
    zxing生成高容错率二维码,以及添加文字
    LVM磁盘划分
    阿里云盘扩容(SUSE Linux下)
  • 原文地址:https://www.cnblogs.com/sueyyyy/p/11793746.html
Copyright © 2011-2022 走看看