欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

TreeSet判斷重復(fù)元素解析及代碼示例

 更新時間:2018年01月08日 08:41:48   作者:Orisun  
這篇文章主要介紹了TreeSet判斷重復(fù)元素解析及代碼示例,具有一定借鑒價值,需要的朋友可以參考下

TreeSet的底層是TreeMap的keySet(),而TreeMap是基于紅黑樹實現(xiàn)的,紅黑樹是一種平衡二叉查找樹,它能保證任何一個節(jié)點的左右子樹的高度差不會超過較矮的那棵的一倍。

TreeMap是按key排序的,所以TreeSet中的元素也是排好序的。顯然元素在插入TreeSet時compareTo()方法要被調(diào)用,所以TreeSet中的元素要實現(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)文章

  • Springboot詳解RocketMQ實現(xiàn)消息發(fā)送與接收流程

    Springboot詳解RocketMQ實現(xiàn)消息發(fā)送與接收流程

    這篇文章主要介紹了SpringBoot整合RocketMQ實現(xiàn)消息發(fā)送和接收功能,我們使用主流的SpringBoot框架整合RocketMQ來講解,使用方便快捷,本文分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Java超詳細(xì)分析講解final關(guān)鍵字的用法

    Java超詳細(xì)分析講解final關(guān)鍵字的用法

    關(guān)于final關(guān)鍵字,它也是我們一個經(jīng)常用的關(guān)鍵字,可以修飾在類上、或者修飾在變量、方法上,以此看來定義它的一些不可變性!像我們經(jīng)常使用的String類中,它便是final來修飾的類,并且它的字符數(shù)組也是被final所修飾的。但是一些final的一些細(xì)節(jié)你真的了解過嗎
    2022-06-06
  • Java8新特性之新日期時間庫的使用教程

    Java8新特性之新日期時間庫的使用教程

    這篇文章主要給大家介紹了關(guān)于Java8新特性之新日期時間庫使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • java 實現(xiàn)多線程的方法總結(jié)

    java 實現(xiàn)多線程的方法總結(jié)

    這篇文章主要介紹了java 實現(xiàn)多線程的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • 詳解Java中實現(xiàn)SHA1與MD5加密算法的基本方法

    詳解Java中實現(xiàn)SHA1與MD5加密算法的基本方法

    這篇文章主要介紹了詳解Java中實現(xiàn)SHA1與MD5加密算法的基本方法,安全哈希算法第一版和消息摘要算法第五版也是通常人們最常用的加密算法,需要的朋友可以參考下
    2016-04-04
  • Java實現(xiàn)解析.xlsb文件的示例代碼

    Java實現(xiàn)解析.xlsb文件的示例代碼

    這篇文章主要為大家詳細(xì)介紹了Java實現(xiàn)解析.xlsb文件的相關(guān)方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的可以了解一下
    2023-01-01
  • SpringBoot+Shiro+LayUI權(quán)限管理系統(tǒng)項目源碼

    SpringBoot+Shiro+LayUI權(quán)限管理系統(tǒng)項目源碼

    本項目旨在打造一個基于RBAC架構(gòu)模式的通用的、并不復(fù)雜但易用的權(quán)限管理系統(tǒng),通過SpringBoot+Shiro+LayUI權(quán)限管理系統(tǒng)項目可以更好的幫助我們掌握springboot知識點,感興趣的朋友一起看看吧
    2021-04-04
  • Springboot實現(xiàn)郵件發(fā)送功能

    Springboot實現(xiàn)郵件發(fā)送功能

    這篇文章主要為大家詳細(xì)介紹了Springboot實現(xiàn)郵件發(fā)送功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • springcloud+nacos實現(xiàn)灰度發(fā)布示例詳解

    springcloud+nacos實現(xiàn)灰度發(fā)布示例詳解

    這篇文章主要介紹了springcloud+nacos實現(xiàn)灰度發(fā)布,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • Springboot2.7+Minio8 實現(xiàn)大文件分片上傳

    Springboot2.7+Minio8 實現(xiàn)大文件分片上傳

    本文主要介紹了Springboot2.7+Minio8 實現(xiàn)大文件分片上傳,通過文件切片上傳,我們能夠提高文件上傳的速度,優(yōu)化用戶體驗,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12

最新評論