java用TreeMap座位排序

本文介绍了一个使用Java编程语言实现的例子,展示了如何利用TreeMap进行学生座位的排序和检索。通过自定义Seat类实现Comparable接口,可以按座位坐标(x, y)排序,再配合Student类存储学生信息,实现了座位与学生的一一对应。

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

class Seat implements Comparable<Seat>{
	int x,y;
	

	public Seat(int i, int j) {
		this.x=i;
		this.y=j;
	}

	

	
	@Override
	public int compareTo(Seat o) {
		return this.x!=o.x?this.x-o.x:this.y-o.y;//先根据x排序,在根据y
	}

	@Override
	public String toString() {
		return "(" + x + ","+ y + ")";
	}
	
	
}
class Student{
	String name;
	public Student(String name) {
		super();
		this.name = name;
	}
	@Override
	public String toString() {
		return   name +"同学";
	}

	

}
public class test5 {
	public static void main(String[] args) {
		TreeMap<Seat, Student> s161 = new TreeMap<Seat, Student>();
		s161.put(new Seat(1,1), new Student("张三"));
		s161.put(new Seat(1,2), new Student("李四"));
		s161.put(new Seat(2,1), new Student("王五"));
		s161.put(new Seat(2,2), new Student("赵六"));
		
		
		System.out.println(s161);
		Map.Entry<Seat, Student> r=s161.firstEntry();//寻找第一位位置同学
		System.out.println(r.getKey()+"->"+r.getValue());
		
		
	}
}

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值