java中TreeMap排序的示例代码
作者:AsuraDong 时间:2023-02-17 15:39:30
1. 定义TreeMap的排序方法
使用Comparator对象作为参数
需要注意的是:排序方法是针对键的,而不是值的。如果想针对值,需要更麻烦的一些方法(重写一些方法)
TreeMap<Screen,Integer> res = new TreeMap<Screen, Integer>(new Comparator<Screen>() {
@Override
public int compare(Screen screen1, Screen t1) { // 定义TreeMap的排序方法
return screen1.compareTo(t1); // TreeMap的排序方法是:调用screen的比较方法
}
});
2. 定义里面的对象的比较方法
继承Comparable接口
public class Screen implements Comparable{
private double size,price;
...
@Override
public int compareTo(Object s){ // 定义比较方法
Screen screen = (Screen)s;
return this.price>screen.getPrice()?-1:1; // 返回负整数和正整数
}
}
3. 所有代码
按照Screen的价钱排序
Screen.java
import java.util.*;
import java.lang.Integer;
public class Screen implements Comparable{
private double size,price;
public Screen(){}
public void setSize(double size){
this.size = size;
}
public void setPrice(double price){
this.price = price;
}
public double getSize(){ return this.size;}
public double getPrice() { return this.price;}
public void show(){
System.out.println("size is: "+this.size+"; price is: "+this.price);
}
@Override
public int compareTo(Object s){ // 定义比较方法
Screen screen = (Screen)s;
return this.price>screen.getPrice()?-1:1; // 返回负整数和正整数
}
}
TestScreen.java
import java.util.Comparator;
import java.util.Scanner;
import java.util.TreeMap;
import problem2.Screen;
public class TestScreen {
final static int MAX_NUM = 8;
public static void main(String []args){
TreeMap<Screen,Integer> res = new TreeMap<Screen, Integer>(new Comparator<Screen>() {
@Override
public int compare(Screen screen1, Screen t1) { // 定义TreeMap的排序方法
return screen1.compareTo(t1); // TreeMap的排序方法是:调用screen的比较方法
}
});
double price, size;
Scanner scan = new Scanner(System.in);
for(int i=0;i<MAX_NUM;++i){
Screen screen = new Screen();
size = scan.nextDouble();
price = scan.nextDouble();
screen.setSize(size);
screen.setPrice(price);
res.put(screen,i);
}
for(Screen screen:res.keySet()){
screen.show();
}
return ;
}
}
// 测试样例(输入)
// 1 2
// 3 4
// 5 6
// 7 8
// 9 10
// 1 2
// 3 4
// 3 4
来源:http://www.jianshu.com/p/dc0e6c3a7c67
标签:java,TreeMap,排序
0
投稿
猜你喜欢
Hibernatede 一对多映射配置方法(分享)
2021-08-27 02:26:32
c# 反射+自定义特性保存数据至本地
2023-03-14 03:07:40
mybatis-generator自动生成dao、mapping、bean配置操作
2023-08-17 14:05:30
用java实现跳动的小球示例代码
2021-09-13 11:41:34
Android中EditText和AutoCompleteTextView设置文字选中颜色方法
2022-12-05 04:45:30
C# 表达式目录树Expression的实现
2023-04-03 22:57:32
Java女装商城系统的实现流程
2023-09-23 11:53:51
Android基于google Zxing实现各类二维码扫描效果
2022-04-10 17:28:59
Android XUtils3框架的基本使用方法(二)
2021-08-03 16:32:45
Android线程实现图片轮播
2021-06-02 17:49:23
Mybatis Select Count(*)的返回值类型介绍
2022-06-17 12:51:19
Android 6.0调用相机图册崩溃的完美解决方案
2022-10-13 02:00:39
SpringCloudConfig之client端报错Could not resolve placeholder问题
2023-11-23 11:19:17
一行命令同时修改maven项目中多个module的版本号的方法
2023-09-13 09:43:10
java获取包下被指定注解的类过程解析
2023-08-08 11:12:27
Java C++ 算法题解leetcode1608特殊数组特征值
2023-05-21 21:09:01
JavaMail实现带附件的邮件发送
2021-10-21 15:00:09
详解Springboot之整合JDBCTemplate配置多数据源
2023-05-03 13:40:43
阿里云OSS域名配置及简单上传的示例代码
2022-04-08 19:14:32
C#实现自动生成电子印章
2022-12-08 10:47:58