Java TreeMap排序算法实例

作者:johennes 时间:2023-02-25 10:26:20 

本文实例讲述了Java TreeMap排序算法。分享给大家供大家参考,具体如下:

TreeMap 和 HashMap 用法大致相同,但实际需求中,我们需要把一些数据进行排序;

以前在项目中,从数据库查询出来的数据放在List中,顺序都还是对的,但放在HashMap中,顺序就完全乱了。

为了处理排序的问题:

1. 对于一些简单的排序,如:数字,英文字母等


TreeMap hm = new TreeMap<String, String>(new Comparator() {
   public int compare(Object o1, Object o2) {
      //如果有空值,直接返回0
      if (o1 == null || o2 == null)
        return 0;
      return String.valueOf(o1).compareTo(String.valueOf(o2));
   }
});

备注:

compareTo(String str) :是String 提供的一个方法,如果参数字符串等于此字符串,则返回 0 值;如果按字典顺序此字符串小于字符串参数,则返回一个小于 0 的值;如果按字典顺序此字符串大于字符串参数,则返回一个大于 0 的值。

int compare(T o1,T o2):随第一个参数小于、等于或大于第二个参数而分别返回负整数、零或正整数。

2. 对于处理有中文排序的问题


TreeMap hm = new TreeMap<String, String>(new Comparator() {
    public int compare(Object o1, Object o2) {
       //如果有空值,直接返回0
       if (o1 == null || o2 == null)
          return 0;
      CollationKey ck1 = collator.getCollationKey(String.valueOf(o1));
      CollationKey ck2 = collator.getCollationKey(String.valueOf(o2));
      return ck1.compareTo(ck2);
   }
});

备注: CollationKey:CollationKey 表示遵守特定 Collator 对象规则的 String。

比较两个CollationKey 将返回它们所表示的 String 的相对顺序。使用 CollationKey来比较 String 通常比使用 Collator.compare 更快。因此,当必须多次比较 String 时(例如,对一个 String 列表进行排序),使用 CollationKey 会更高效。

实例:


package ChineseSort;
import java.util.Collection;
import java.util.Iterator;
import java.util.SortedMap;
import java.util.TreeMap;
public class TestSort {
public static void main(String[] args) {
 // TODO Auto-generated method stub
 CollatorComparator comparator = new CollatorComparator();
 TreeMap map = new TreeMap(comparator);
 for(int i=0; i<10; i++) {
   String s = ""+(int)(Math.random()*1000);
   map.put(s,s);
 }
 map.put("abcd","abcd");
 map.put("Abc", "Abc");
 map.put("bbb","bbb");
 map.put("BBBB", "BBBB");
 map.put("北京","北京");
 map.put("中国","中国");
 map.put("上海", "上海");
 map.put("厦门", "厦门");
 map.put("香港", "香港");
 map.put("碑海", "碑海");
 Collection col = map.values();
 Iterator it = col.iterator();
 while(it.hasNext()) {
   System.out.println(it.next());
 }
}
}

比较器类:


package ChineseSort;
import java.text.CollationKey;
import java.text.Collator;
import java.util.Comparator;
public class CollatorComparator implements Comparator {
Collator collator = Collator.getInstance();
public int compare(Object element1, Object element2) {
 CollationKey key1 = collator.getCollationKey(element1.toString());
 CollationKey key2 = collator.getCollationKey(element2.toString());
 return key1.compareTo(key2);
}
}

运行该类,运行结果如下:


325
62
653
72
730
757
874
895
909
921
Abc
abcd
bbb
BBBB
碑海
北京
上海
厦门
香港
中国

此时可以看到中文的排序已经完成正常。如果想不让英文区分大小写,则修改CollatorComparator类,找到


element1.toString()

修改为:


element1.toString().toLowerCase()

当然你改成转换成大写的也无所谓了,当然


element2.toString()

也要同时修改为


element2.toString().toLowerCase()

希望本文所述对大家java程序设计有所帮助。

标签:Java,TreeMap,排序算法
0
投稿

猜你喜欢

  • Java异常 Exception类及其子类(实例讲解)

    2022-04-05 13:40:16
  • Android XRecyclerView实现多条目加载

    2021-10-15 07:32:21
  • Spring Security和Shiro的相同点与不同点整理

    2023-01-15 17:07:20
  • Spring Boot中配置定时任务、线程池与多线程池执行的方法

    2021-08-08 13:31:30
  • Java Swing实现窗体添加背景图片的2种方法详解

    2021-10-26 19:01:18
  • Java数组(Array)最全汇总(中篇)

    2022-09-05 06:01:02
  • 详解Java中的线程池

    2023-11-10 16:33:27
  • Android studio 混淆配置详解

    2023-02-16 19:17:22
  • java(jdk)环境变量配置(XP、win7、win8)图文教程详解

    2021-11-01 15:06:48
  • Android APK应用安装原理解析之AndroidManifest使用PackageParser.parserPackage原理分析

    2023-05-19 23:58:18
  • Spring Cloud Alibaba 本地调试介绍及方案设计

    2023-05-26 21:24:26
  • C# DateTime.ToString根据不同语言生成相应的时间格式

    2022-04-16 12:34:51
  • Spring Cloud Gateway 默认的filter功能和执行顺序介绍

    2021-07-01 21:31:46
  • C#编程调用Cards.dll实现图形化发牌功能示例

    2022-10-24 12:02:54
  • Java避免死锁_动力节点Java学院整理

    2023-05-07 15:02:03
  • 解决logback-classic 使用testCompile的打包问题

    2021-07-01 08:16:50
  • Java基于接口实现模拟动物声音代码实例

    2022-07-28 04:46:07
  • 用C# 实现鼠标框选效果的实现代码

    2023-04-18 14:08:26
  • C#获取真实IP地址(IP转为长整形、判断是否内网IP的方法)

    2022-01-31 08:50:06
  • Android RecyclerView 上拉加载更多及下拉刷新功能的实现方法

    2021-10-06 22:37:24
  • asp之家 软件编程 m.aspxhome.com