java定义一个tree类_java – 如何在TreeSet中使用自定义类?

如果没有实现Comparable< Node>,它将无法对其进行排序,并且在重写equals()和hashCode()之前它不适合于设置操作. (您不必为TreeSet重写equals和hashCode,但这样做是有意义的.)

像这样的东西:

final class Node implements Comparable {

private final int x;

private final int y;

Node(int x, int y) {

this.x = x;

this.y = y;

}

@Override public boolean equals(Object other) {

if (!(other instanceof Node)) {

return false;

}

Node otherNode = (Node) other;

return x == otherNode.x && y == otherNode.y;

}

@Override public int hashCode() {

return x * 31 + y * 17; // For example...

}

@Override public int compareTo(Node other) {

// As of Java 7, this can be replaced with

// return x != other.x ? Integer.compare(x, other.x)

// : Integer.compare(y, other.y);

if (x < other.x || (x == other.x && y < other.y)) {

return -1;

}

return x == other.x && y == other.y ? 0 : 1;

}

}

(请注意,按照惯例,类名称将是Node,而不是节点.)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值