java中TreeSet集合如何實現元素的判重

  1 /*
  2 看一下部分的TreeSet源碼....
  3 public class TreeSet<E> extends AbstractSet<E>
  4     implements NavigableSet<E>, Cloneable, java.io.Serializable
  5 {
  6     private transient NavigableMap<E,Object> m;
  7     //NavigableMap繼承SortedMap, 二者都是接口,在TreeMap中有實現
  8     private static final Object PRESENT = new Object();
  9 
 10     TreeSet(NavigableMap<E,Object> m) {
 11         this.m = m;
 12     }
 13     第一種構造方法
 14     public TreeSet(Comparator<? super E> comparator) {
 15         this(new TreeMap<>(comparator));
 16     }
 17     第二種構造方法
 18     public TreeSet() {
 19         this(new TreeMap<E,Object>());
 20     }
 21     ..........
 22     public boolean add(E e) {
 23         return m.put(e, PRESENT)==null;
 24 
 25     /*
 26         再看一下 TreeMap 中是如何實現的 put()函數的
 27         public V put(K key, V value) {
 28         Entry<K,V> t = root;
 29         if (t == null) {
 30             compare(key, key); // type (and possibly null) check
 31 
 32             root = new Entry<>(key, value, null);
 33             size = 1;
 34             modCount++;
 35             return null;
 36         }
 37         int cmp;
 38         Entry<K,V> parent;
 39         // split comparator and comparable paths
 40         Comparator<? super K> cpr = comparator;
 41         if (cpr != null) {
 42             do {
 43                 parent = t;
 44                 cmp = cpr.compare(key, t.key);
 45                 if (cmp < 0)
 46                     t = t.left;
 47                 else if (cmp > 0)
 48                     t = t.right;
 49                 else
 50                     return t.setValue(value);
 51             } while (t != null);
 52         }
 53         else {
 54             if (key == null)
 55                 throw new NullPointerException();
 56             Comparable<? super K> k = (Comparable<? super K>) key;
 57             do {
 58                 parent = t;
 59                 cmp = k.compareTo(t.key);
 60                 if (cmp < 0)
 61                     t = t.left;
 62                 else if (cmp > 0)
 63                     t = t.right;
 64                 else
 65                     return t.setValue(value);
 66             } while (t != null);
 67         }
 68         Entry<K,V> e = new Entry<>(key, value, parent);
 69         if (cmp < 0)
 70             parent.left = e;
 71         else
 72             parent.right = e;
 73         fixAfterInsertion(e);
 74         size++;
 75         modCount++;
 76         return null;
 77     }
 78     */
 79     }
 80 }
 81 
 82 也就是說TreeSet內部實現使用TreeMap這個類來完成的
 83 TreeSet的內部實現元素之間是否相等?
 84 如果指定了Comparator(也就是利用第一種構造方法), 那么就用其中的compare方法進行比較
 85 否則就用Comparable中的compareTo()方法進行元素的比較
 86 */
 87 
 88 import java.util.*;
 89 public class CompTest{
 90     public static void main(String args[]){
 91         Set<myClass> st = new TreeSet<myClass>();
 92         st.add(new myClass(1, "fd"));
 93         st.add(new myClass(2, "fff"));
 94         st.add(new myClass(2, "tttt"));
 95         st.add(new myClass(1, "fd"));
 96 
 97         for(Iterator<myClass> it = st.iterator(); it.hasNext();)
 98             System.out.println(it.next());
 99     }
100 }
101 
102 class myClass implements Comparable<myClass>{
103 
104    public int x;
105    public String name;
106    public myClass(int x, String name){
107        this.x=x;
108        this.name=name;
109    }
110    public int compareTo(myClass tmp){
111        if(this.x==tmp.x)
112           return this.name.compareTo(tmp.name);
113        else return this.x-tmp.x;
114    }
115   
116    public String toString(){
117       return x+" "+name;
118    }
119 }

?

轉載于:https://www.cnblogs.com/hujunzheng/p/3814902.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531948.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531948.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531948.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

php中改變函數路由,通過PHP重啟路由器以更換IP(原創)

在采集大批量數據時常常會觸發對方服務器的“自我保護”&#xff0c;請求過于頻繁就限制訪問。這時需要停留很長一段時間(十幾分鐘到幾十分鐘不等)才能恢復訪問&#xff0c;這樣采集數據的速度就受到非常大的限制。解決方法有兩個&#xff1a;1 通過圖片識別繞過驗證碼機制&…

axure 畫小程序效果圖_APP詳情頁如何用Axure畫出來

詳情頁是App原型中比較復雜的頁面類型&#xff0c;熟悉它的常用套路有助于快速畫出。之前的文章已經講解了APP常見功能中的頁面模板、下導航、上導航、列表頁怎么畫出來&#xff0c;請繼續關注浪子教你畫APP原型后續的其他功能模塊。APP詳情頁往往包含上導航&#xff0c;內容區…

HashSet中實現不插入重復的元素

/* 看一下部分的HashSet源碼.... public class HashSet<E>extends AbstractSet<E>implements Set<E>, Cloneable, java.io.Serializable {static final long serialVersionUID -5024744406713321676L;private transient HashMap<E,Object> map;privat…

tuxedo錯誤碼6_TUXEDE返回的所有錯誤代碼

TUXEDE返回的所有錯誤代碼tuxedo/include/atmi.h定于了TUXEDE返回的所有錯誤代碼。/** tperrno values - error codes* The man pages explain the context in which the following error codes* can return.*/#define TPMINVAL 0 /* minimum error message */#define TPEABORT…

java中finally和return的執行順序

注意&#xff1a;return的位置。。。從這幾個例子中可以看到&#xff0c;如果try之前沒有有條件的return&#xff0c;則try..catch..finally語句塊中的語句都是順序執行&#xff08;如果try中或者catch中 有return語句&#xff0c;那么先執行該return&#xff0c;然后執行final…

oracle如何設置權限,ORACLE的權限設置

創建用戶create user abc identified by 123;----------------------------------------------------授權grant create session,create table to abcgrant create sysdba to database----------------------------------------------------然后conn abc密碼&#xff1a;123----…

有關try..catch..finally處理異常的總結

//看一下下面的程序&#xff0c;你能正確的寫出不同的testEx2()方法時&#xff0c;程序的最終打印出來的數據嗎....先不要看下面的答案 public class ExceptionTest { public ExceptionTest() { } boolean testEx() throws Exception { boolean ret true; try { ret te…

oracle key的含義,v$session SERIAL#字段的含義

liyx&#xff1a;#!/bin/bash||#Write by liyx||||#數據庫服務器地址||DBHOSTlocalhost||#數據庫登錄名||USERNAMEroot||#數據庫密碼||PASSWORDroot||#需要備份的數據庫 或 輸入類似 db1 db2 的列表清單 例 DBNAMES"all"||DBNAMES"ess_simple"||#備份MYSQL…

java.util.Scanner簡單應用

import java.util.Scanner; import java.io.*; public class FileScannerTest{public static void main(String args[]){ //**************Scanner 的一般用//1.public Scanner(InputStream source),利用InputStream 對象進行構造Scanner myScanner1 new Scanner(System.in);w…

oracle能查dml記錄么,如何查詢DML操作的詳細記錄

可以通過flashback_transaction_qurey視圖查詢eg:SQL> desc flashback_transaction_queryName Null? Type----------------------------------------- -------- ----------------------------XID …

krpano 場景切換 通知_一個基于Vulkan的異步場景加載設計

異步場景加載基本流程驗證完成。此方法理論上只需要使用3個Vulkan的指令隊列。對于移動平臺上的Vulkan&#xff0c;指令隊列數量極少&#xff0c;比如Adreno640只有3個指令隊列可用。所以理論上這一設計也適合目前的移動平臺使用。(1) graphic_queue&#xff1a;用于完成當前場…

oracle 數據庫回閃,各種數據庫閃回的總結

本帖最后由 guoyJoe 于 2013-3-26 21:15 編輯一、Fashback Query閃回查詢:Books-->APP-->Application Developers Guide - Fundamentals-->Flashback&#xff11;、應用Flashback Query查詢過去的數據select * from t1 as of scn 44545454;select * from t1 as of tim…

poj 2528 Mayor's posters(線段樹+離散化)

1 /*2 poj 2528 Mayors posters 3 線段樹 離散化4 5 離散化的理解&#xff1a;6 給你一系列的正整數&#xff0c; 例如 1&#xff0c; 4 &#xff0c; 100&#xff0c; 1000000000&#xff0c; 如果利用線段樹求解的話&#xff0c;很明顯7 會導致內存的耗盡。所以我們做一…

漢儀尚巍手書有版權嗎_為什么“漢儀尚巍手書”會大行天下?

昨夜&#xff0c;我寫了篇文章《莫選最丑尚巍體&#xff0c;要選美麗中國字&#xff01;》發到朋友圈、微信群里&#xff0c;得到了一些朋友的反饋&#xff0c;有位朋友居然還認識尚巍&#xff0c;把他的微信推給了我。我加了尚巍的微信&#xff0c;待他通過后&#xff0c;便連…

如何查詢linux服務器的網卡,Linux服務器如何查看有沒有無線網卡

還是實驗室那臺服務器&#xff0c;連不上網。有沒有界面&#xff0c;所以想著如何用一些命令來鏈接上熱點。當然&#xff0c;在Linux下鏈接wifi沒有win下那么一點就好了&#xff01;首先我們需要的基本條件就是&#xff1a; 服務器上有無線網卡。[roottomato2 ~]# iwconfiglo n…

java中如何生成可執行的jar文件

java中如何生成可執行的jar文件最簡單的方法就是&#xff1a;jar -cfe Card.jar CardLayoutDemo CardLayoutDemo$1.class CardLayoutDemo$myAct ionListener.class CardLayoutDemo.class myClosingListener.class myPanel.class jar命令為java自帶的專用打包工具&#xff1b; c…

ecs硬盤數據遷移_阿里云ECS新增數據盤以及遷移數據方法

第一、檢查數據占用以及數據盤我們從探針可以看到&#xff0c;本身有30GB的硬盤只用到不到10GB&#xff0c;而且系統和WDCP面板/網站都系統盤中。通過fdisk -l 我們可以看到還有21GB的沒有格式化和掛載&#xff0c;系統只用到10.7GB。第二、對數據盤分區fdisk /dev/xvdb第三、查…

linux文件瀏覽 ls,linux瀏覽文件命令

在linux下我們要瀏覽文件的內容&#xff0c;可以通過相關的命令來執行操作&#xff0c;下面由學習啦小編為大家整理了linux下瀏覽文件命令的相關知識&#xff0c;希望對大家有所幫助!linux瀏覽文件命令1.cat[功能說明]查看文件的內容#cat本身是一個串接命令&#xff0c;把指定一…

python的多行語句可以使用反斜杠_python 為什么不用分號作終止符?

作者&#xff1a;豌豆花下貓 來源&#xff1a;Python貓一般而言&#xff0c;編程語言中使用分號“;”來實現兩種目的&#xff1a;作為語句分隔符&#xff1a;使用分號來分隔語句&#xff08;statement&#xff09;&#xff0c;這樣就能在一行代碼中書寫多條語句&#xff08;一行…

linux dlopen 內存,Linux下加載庫的有關問題(dlopenm, dlsym)

Linux下加載庫的問題(dlopenm, dlsym)如題&#xff0c; 程序中發現load庫成功&#xff0c;但是加載函數的時候報錯: undefined symbol functionname是很簡單的一個東西&#xff0c;因為不熟悉&#xff0c;所以老是弄不好&#xff0c;請各位指導&#xff01;代碼如下&#xff1a…