java - 尝试按列表项对 HashMap<String, List<String>> 进行排序

标签 java algorithm list sorting hashmap

我有一个 HashMap<String, List<String>>,但我不知道如何按第三个列表项对其进行排序。我试过使用比较器,但我可以用它来查看第三个列表项。

我正在使用的 HashMap:

HashMap<String, List<String>> hmap= new HashMap<String, List<String>>();
List<String> prod1 = new ArrayList<String>();
prod1.add("123456789102");
prod1.add("3.0");
prod1.add("8");
hmap.put("Blue magazine", prod1);
List<String> prod2 = new ArrayList<String>();
prod2.add("123456789102");
prod2.add("2.0");
prod2.add("7");
hmap.put("Pink magazine", prod2);
List<String> prod3 = new ArrayList<String>();
prod3.add("123456789102");
prod3.add("1.0");
prod3.add("6");
hmap.put("Black magazine", prod3);

我正在尝试将其排序为低 - 高(整数)第二个列表项。
所以:6 - 7 - 8
    List list = new LinkedList(map.entrySet());
    Collections.sort(list, new Comparator() {
        public int compare(Object o1, Object o2) {
        return ((Comparable) ((Map.Entry)(o1)).getValue()).compareTo(((Map.Entry)(o2)).getValue());
        }
    });

编辑:为每个请求添加了比较器尝试。

最佳答案

另一种不需要同时访问 list 的方法和 hmap在 Comparator 中并产生一个排序的 Map:

List<Map.Entry<String,List<String>>> list = 
  new LinkedList<Map.Entry<String,List<String>>>(hmap.entrySet());

Collections.sort( list, new Comparator<Map.Entry<String,List<String>>>() {
    public int compare( Map.Entry<String,List<String>> o1,
                        Map.Entry<String,List<String>> o2) {
        return o1.getValue().get( 2 ).compareTo(  o2.getValue().get(2) );
    }
});

Map<String, List<String>> result = new LinkedHashMap<String, List<String>>();
for ( Map.Entry<String, List<String>> n : list )
    result.put( n.getKey(), n.getValue() );

关于java - 尝试按列表项对 HashMap<String, List<String>> 进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31703420/

相关文章:

java - 在Java中,如何动态确定数组的类型?

java - 在 FF 中运行良好的脚本无法在 IE 中运行

java - @FXMLViewFlowContext 空指针异常

c - 没有库函数的C中的反向字符串函数

python - 集中处理列表中的每个值

java - 从类调用方法与创建类和调用方法有何直接不同?

algorithm - 在另一个字符串中查找最大相似子字符串

windows - Windows 资源管理器使用的排序顺序中的第一个字符是什么?

python - 使用字典理解反转一对多映射

java - 如何将数组列表的相等性与现代 Java 进行比较?