Java-TreeMap对Key/Value自定排序

2024-03-08 12:48

本文主要是介绍Java-TreeMap对Key/Value自定排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java-TreeMap对Key/Value自定排序

Key自定义排序:

实现Comparator接口:

1)重写接口Comparator中的compare方法

//实现接口:Comparator
class MyComparator implements Comparator{//自定义排序,对价格升序排序//实例key为double类型public int compare(Object o1,Object o2) {double a=(double)o1;double b=(double)o2;if(a-b>1e-6) {return 1;}else if(b-a>1e-6) {return -1;}else {return 0;}}
}

2)创建方法:将原map值搬入定义有排序规则的另一map

    //创建map,key为价格,value为尺寸Map<Double,Double> SortByPrice=new TreeMap<>();//调用重排方法SortByPrice=cmp(SortByPrice);//map重排方法public static Map<Double,Double> cmp(Map<Double,Double> map){//创建新的map,使用自定义的key排序规则Map<Double,Double> Res=new TreeMap<>(new MyComparator());Res.putAll(map);	//装入原先map的数据return Res;	//返回自定义key排序的map对象}

 

实现Comparable接口:

1)将Comparable的子类作为TreeMap的key值,并重写Comparable中的compareTo方法

Tip:以此为key的map将按重写的compareTo规则进行排序

//MyKey.java
//实现Comparable接口
class MyKey implements Comparable{public double Pirce;public MyKey(double Price) {this.Pirce=Price;}//对Price进行升序排序public int compareTo(Object o) {MyKey key=(MyKey)o;if(key.Pirce-this.Pirce>1e-6) {return -1;}else if(this.Pirce-key.Pirce>1e-6) {return 1;}else {return 0;}}
}

总结:

留个坑给自己,第二种方法会不会导致TreeMap中的containsKey方法不能正常使用,是否得重写equals和compare,过后会有个更新。

 

Value自定义排序:

实现Comparator接口

1)重写Comparator中的compare方法

    /*自定排序:对单词出现次数(Value)降序* 重写compare实现*/private class SortByValue implements Comparator<Map.Entry<String, Integer>>{@Overridepublic int compare(Entry<String, Integer> l, Entry<String, Integer> r) {// TODO Auto-generated method stubreturn r.getValue()-l.getValue();}}

2)将TreeMap转为数据类型为Map.Entry的ArraysList,调用Collections的sort方法

private TreeMap<String,Integer> Words_Analysis;
private List<Map.Entry<String,Integer>> Result;/*将map统计的结果以Entry-List形式存储* 调用集合类中的Sort方法*/
public void Sort() {Result.addAll(Words_Analysis.entrySet());SortByValue cmp=new SortByValue();Collections.sort(Result, cmp);
}

 

上述引用实例的源码(GitHub):

对Key自定义排序:

1)实现Comparator接口:对某商品价格的排序

2)实现Comparable接口:对某商品价格的排序

对Value自定义排序:

1)实现Comparator接口:统计本地txt文件中单词个数

 

这篇关于Java-TreeMap对Key/Value自定排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/787140

相关文章

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++