TreeSet判斷重復(fù)元素解析及代碼示例
TreeSet的底層是TreeMap的keySet(),而TreeMap是基于紅黑樹實(shí)現(xiàn)的,紅黑樹是一種平衡二叉查找樹,它能保證任何一個節(jié)點(diǎn)的左右子樹的高度差不會超過較矮的那棵的一倍。
TreeMap是按key排序的,所以TreeSet中的元素也是排好序的。顯然元素在插入TreeSet時compareTo()方法要被調(diào)用,所以TreeSet中的元素要實(shí)現(xiàn)Comparable接口。TreeSet作為一種Set,它不允許出現(xiàn)重復(fù)元素。TreeSet是用compareTo()來判斷重復(fù)元素的,而非equals(),看下面代碼。
import java.util.TreeSet;
import org.junit.Test;
public class TestTreeSet {
class Combine implements Comparable<Combine> {
private int p1;
private int p2;
public Combine(int p1, int p2) {
this.p1 = p1;
this.p2 = p2;
}
@Override
public int hashCode() {
return p1 * 31 + p2;
}
@Override
public Boolean equals(Object obj) {
System.out.print("whether equal " + this + " and " + obj);
Boolean rect = false;
if (obj instanceof Combine) {
System.out.println("whether equal " + this + " and " + obj);
Combine other = (Combine) obj;
rect = (this.p1 == other.getP1() && this.p2 == other.getP2());
}
System.out.println(": " + rect);
return rect;
}
@Override
public int compareTo(Combine o) {
System.out.print("compare " + this + " and " + o);
// 排序時只考慮p1
if (this.p1 < o.p1) {
System.out.println(", return -1");
return -1;
} else if (this.p1 > o.p1) {
System.out.println(", return 1");
return 1;
} else {
System.out.println(", return 0");
return 0;
}
}
@Override
public String toString() {
return "(" + p1 + "," + p2 + ")";
}
public int getP1() {
return p1;
}
public void setP1(int p1) {
this.p1 = p1;
}
public int getP2() {
return p2;
}
public void setP2(int p2) {
this.p2 = p2;
}
}
@Test
public void test() {
Combine c1 = new Combine(1, 2);
Combine c2 = new Combine(1, 2);
Combine c3 = new Combine(1, 3);
Combine c4 = new Combine(5, 2);
TreeSet<Combine> set = new TreeSet<Combine>();
set.add(c1);
set.add(c2);
set.add(c3);
set.add(c4);
while (!set.isEmpty()) {
//按順序輸出TreeSet中的元素
Combine combine = set.pollFirst();
System.out.println(combine.getP1() + "\t" + combine.getP2());
}
}
}
輸出:
compare (1,2) and (1,2), return 0
compare (1,2) and (1,2), return 0
compare (1,3) and (1,2), return 0
compare (5,2) and (1,2), return 1
1 2
5 2
我們看到不論compareTo()返回的是不是相等,equals()方法都沒有被調(diào)用。
總結(jié)
以上就是本文關(guān)于TreeSet判斷重復(fù)元素解析及代碼示例的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
Spring中@Validated和@Valid區(qū)別淺析
@Valid是javax.validation里的,?@Validated是@Valid?的一次封裝,是Spring提供的校驗(yàn)機(jī)制使用,下面這篇文章主要給大家介紹了關(guān)于Spring中@Validated和@Valid區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-04-04
springmvc參數(shù)為對象,數(shù)組的操作
這篇文章主要介紹了springmvc參數(shù)為對象,數(shù)組的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
iOS socket網(wǎng)絡(luò)編程實(shí)例詳解
socket是一個針對TCP和UDP編程的接口,你可以借助它建立TCP連接等。這篇文章主要介紹了iOS socket網(wǎng)絡(luò)編程 ,需要的朋友可以參考下2017-03-03
java實(shí)現(xiàn)開根號的運(yùn)算方式
這篇文章主要介紹了java實(shí)現(xiàn)開根號的運(yùn)算方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07
Java網(wǎng)絡(luò)編程基礎(chǔ)教程之Socket入門實(shí)例
這篇文章主要介紹了Java網(wǎng)絡(luò)編程基礎(chǔ)教程之Socket入門實(shí)例,本文講解了創(chuàng)建Socket、Socket發(fā)送數(shù)據(jù)、Socket讀取數(shù)據(jù)、關(guān)閉Socket等內(nèi)容,都是最基礎(chǔ)的知識點(diǎn),需要的朋友可以參考下2014-09-09
Spring?MVC和springboot靜態(tài)資源處理問題
這篇文章主要介紹了Spring?MVC和springboot靜態(tài)資源處理問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08

