Java TreeMap排序算法实例

发布时间 - 2026-01-11 02:13:31    点击率:

本文实例讲述了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数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

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


# Java  # TreeMap  # 排序算法  # Java TreeMap升序|降序排列和按照value进行排序的案例  # JAVA使用TreeMap对字符串进行排序  # java中TreeMap排序的示例代码  # 浅谈java中的TreeMap 排序与TreeSet 排序  # 关于TreeMap自定义排序规则的两种方式  # 厦门  # 香港  # 上海  # 北京  # 中国  # 放在  # 操作技巧  # 相关内容  # 第一个  # 也要  # 感兴趣  # 数据结构  # 第二个  # 英文  # 给大家  # 可以看到  # 更快  # 于此  # 转换成  # 更多关于 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 深圳网站制作培训,深圳哪些招聘网站比较好?  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  Python结构化数据采集_字段抽取解析【教程】  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  太平洋网站制作公司,网络用语太平洋是什么意思?  手机软键盘弹出时影响布局的解决方法  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  node.js报错:Cannot find module &#39;ejs&#39;的解决办法  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  C++时间戳转换成日期时间的步骤和示例代码  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  JavaScript中的标签模板是什么_它如何扩展字符串功能  如何在Windows虚拟主机上快速搭建网站?  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  LinuxCD持续部署教程_自动发布与回滚机制  如何用免费手机建站系统零基础打造专业网站?  Laravel如何生成URL和重定向?(路由助手函数)  Laravel事件监听器怎么写_Laravel Event和Listener使用教程  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  如何快速重置建站主机并恢复默认配置?  Laravel如何创建自定义Artisan命令?(代码示例)  网站制作报价单模板图片,小松挖机官方网站报价?  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  如何用美橙互联一键搭建多站合一网站?  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  黑客如何利用漏洞与弱口令入侵网站服务器?  如何生成腾讯云建站专用兑换码?  怎么用AI帮你设计一套个性化的手机App图标?  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  如何在万网ECS上快速搭建专属网站?  phpredis提高消息队列的实时性方法(推荐)  Laravel怎么使用Intervention Image库处理图片上传和缩放  如何在阿里云购买域名并搭建网站?  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  Claude怎样写结构化提示词_Claude结构化提示词写法【教程】  昵图网官网入口 昵图网素材平台官方入口