Java集合类中TreeMap的应用

本文介绍如何在Java中使用自定义比较器实现TreeMap的数据排序,包括类Person的实现和MyComparator比较器的定义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.util.Comparator;
import java.util.Iterator;
import java.util.Set;
import java.util.TreeMap;


public class TreeMapTest
{
public static void main(String[] args)
{
Person p1 = new Person(100);
Person p2 = new Person(70);
Person p3 = new Person(90);
Person p4 = new Person(60);

TreeMap<Integer, Person> treeMap = new TreeMap<Integer, Person>(new MyComparator());

treeMap.put(Integer.valueOf(p1.getScore()), p1);
treeMap.put(Integer.valueOf(p2.getScore()), p2);
treeMap.put(Integer.valueOf(p3.getScore()), p3);
treeMap.put(Integer.valueOf(p4.getScore()), p4);

Set<Integer> key = treeMap.keySet();
for(Iterator<Integer> iterator = key.iterator(); iterator.hasNext();) {
Integer keyInteger = (Integer)iterator.next();
Person person = (Person)treeMap.get(keyInteger);
System.out.println(keyInteger + ":" + person.toString());
}
}
}


class Person {
private int score;
public Person(int score) {
this.score = score;
}
public int getScore()
{
return score;
}
public void setScore(int score)
{
this.score = score;
}
}
//根据键自定义比较器
class MyComparator implements Comparator<Integer> {
@Override
public int compare(Integer o1, Integer o2)
{
return o2.intValue() - o1.intValue();
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值