java – 按整数值desc排序一个hashmap

前端之家收集整理的这篇文章主要介绍了java – 按整数值desc排序一个hashmap前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如何按整数值对哈希映射进行排序,我找到的答案之一是 here

由Evgeniy Dorofeev撰写,他的回答是这样的

  1. HashMap<String,Integer> map = new HashMap<String,Integer>();
  2. map.put("a",4);
  3. map.put("c",6);
  4. map.put("b",2);
  5. Object[] a = map.entrySet().toArray();
  6. Arrays.sort(a,new Comparator() {
  7. public int compare(Object o1,Object o2) {
  8. return ((Map.Entry<String,Integer>) o2).getValue().compareTo(
  9. ((Map.Entry<String,Integer>) o1).getValue());
  10. }
  11. });
  12. for (Object e : a) {
  13. System.out.println(((Map.Entry<String,Integer>) e).getKey() + " : "
  14. + ((Map.Entry<String,Integer>) e).getValue());
  15. }

产量

  1. c : 6
  2. a : 4
  3. b : 2

我的问题是如何成为描述?如果我想对HashMap Asc进行排序我该怎么做?

最后一个问题是:如何在排序后获得第一个元素?

解决方法

对于反向排序开关o2和o1.要获取第一个元素,只需访问索引0处的数组:
  1. Map<String,Integer> map = new HashMap<>();
  2. map.put("a",4);
  3. map.put("c",6);
  4. map.put("b",2);
  5. Object[] a = map.entrySet().toArray();
  6. Arrays.sort(a,new Comparator() {
  7. public int compare(Object o1,Object o2) {
  8. return ((Map.Entry<String,Integer>) o1).getValue().compareTo(
  9. ((Map.Entry<String,Integer>) o2).getValue());
  10. }
  11. });
  12. for (Object e : a) {
  13. System.out.println(((Map.Entry<String,Integer>) e).getKey() + " : "
  14. + ((Map.Entry<String,Integer>) e).getValue());
  15. }
  16.  
  17. System.out.println("first element is " + ((Map.Entry<String,Integer>) a[0]).getKey() + " : "
  18. + ((Map.Entry<String,Integer>) a[0]).getValue());

哪个打印

b : 2
a : 4
c : 6
first element is b : 2

如果您有权访问lambda表达式,则可以使用以下方法简化排序:

  1. Arrays.sort(a,(o1,o2) ->
  2. ((Map.Entry<String,Integer>) o1).getValue().compareTo(((Map.Entry<String,Integer>) o2).getValue()));

猜你在找的Java相关文章