当前位置: 首页 > 编程笔记 >

Java HashMap两种简便排序方法解析

薛英卫
2023-03-14
本文向大家介绍Java HashMap两种简便排序方法解析,包括了Java HashMap两种简便排序方法解析的使用技巧和注意事项,需要的朋友参考一下

这篇文章主要介绍了Java HashMap两种简便排序方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

HashMap的储存是没有顺序的,而是按照key的HashCode实现.

key=手机品牌,value=价格,这里以这个例子实现按名称排序和按价格排序.

Map phone=new HashMap();
    phone.put("Apple",8899);
    phone.put("SAMSUNG",7000);
    phone.put("Meizu",2698);
    phone.put("Xiaomi",1800);
    System.out.println(phone);

直接输出HashMap得到的是一个无序Map(不是Arraylist那种顺序型储存)

1. 按key排序

对名称进行排序,首先要得到HashMap中键的集合(keySet),并转换为数组,这样才能用Arrays.sort()进行排序

Set set=phone.keySet();
    Object[] arr=set.toArray();
    Arrays.sort(arr);
    for(Object key:arr){
      System.out.println(key);
    }

得到排序好的键值

最后利用HashMap.get(key)得到键对应的值即可

    for(Object key:arr){
      System.out.println(key+": "+phone.get(key));
    }

得到的打印的结果

2.按value排序

对价格进行排序,首先需要得到HashMap中的包含映射关系的视图(entrySet),
如图:

将entrySet转换为List,然后重写比较器比较即可.这里可以使用List.sort(comparator),也可以使用Collections.sort(list,comparator)

转换为list

 List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(phone.entrySet()); //转换为list

使用list.sort()排序

list.sort(new Comparator<Map.Entry<String, Integer>>() {
     @Override
     public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
       return o2.getValue().compareTo(o1.getValue());
     }
   });

使用Collections.sort()排序

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

两种方式结果输出

//for循环
     for (int i = 0; i < list.size(); i++) {
      System.out.println(list.get(i).getKey() + ": " + list.get(i).getValue());
    }   
 //for-each循环
      for (Map.Entry<String, Integer> mapping : list){
      System.out.println(mapping.getKey()+": "+mapping.getValue());
    }

遍历打印输出

//for
    for (int i = 0; i < list.size(); i++) {
      System.out.println(list.get(i).getKey() + ": " +list.get(i).getValue());
    }
    System.out.println();
    //for-each
    for (Map.Entry<String, Integer> mapping : list) {
      System.out.println(mapping.getKey() + ": " +mapping.getValue());
    }

结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • HttpServletResponse提供了如下简便方法: sendRedirect sendError * sendRedirect 方法将设置适当的头和内容体将客户端重定向到另一个地址。使用相对 URL 路径调用该方法是合法的,但是底层的容器必须将传回到客户端的相对地址转换为全路径 URL。无论出于什么原因,如果给定的URL是不完整的,且不能转换为一个有效的URL,那么该方法必须抛出Illeg

  • 本文向大家介绍C#数组排序的两种常用方法,包括了C#数组排序的两种常用方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#数组排序的两种常用方法。分享给大家供大家参考。具体如下: 1.第一个例子 定义代码 测试代码 1.第二个例子 定义代码 测试代码 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍详解Swift model 解析的两种方法,包括了详解Swift model 解析的两种方法的使用技巧和注意事项,需要的朋友参考一下 详解Swift model 解析的两种方法 1. 常规解析方法 model 2. 利用swift自有的函数进行解析-------推荐 如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

  • 本文向大家介绍用Java集合中的Collections.sort方法如何对list排序(两种方法),包括了用Java集合中的Collections.sort方法如何对list排序(两种方法)的使用技巧和注意事项,需要的朋友参考一下 第一种是list中的对象实现Comparable接口,如下: 测试一下: 输出结果如下 a b 第二种方法是根据Collections.sort重载方法来实现,例如:

  • 本文向大家介绍安装docker-compose的两种最简方法,包括了安装docker-compose的两种最简方法的使用技巧和注意事项,需要的朋友参考一下 这里简单介绍下两种安装docker-compose的方式,第一种方式相对简单,但是由于网络问题,常常安装不上,并且经常会断开,第二种方式略微麻烦,但是安装过程比较稳定 方法一: 查看版本信息 但是此方法会经常因为网络的原因而无法安装 方法二:

  • 问题内容: 是否存在将Dialogflow代理连接到我的代码的简便方法?当我将此代码与从Dialogflow代理的设置页面获取的正确projectID一起使用时,出现以下错误: 错误:获取应用程序默认凭据时发生意外错误:无法加载默认凭据。浏览至https://developers.google.com/accounts/docs/application- default-credentials 了