欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Java中怎么刪除數(shù)組中的重復(fù)元素

這篇文章將為大家詳細(xì)講解有關(guān)Java中怎么刪除數(shù)組中的重復(fù)元素,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),榆社企業(yè)網(wǎng)站建設(shè),榆社品牌網(wǎng)站建設(shè),網(wǎng)站定制,榆社網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,榆社網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

問題:比如我有一個數(shù)組(元素個數(shù)為0哈),希望添加進(jìn)去元素不能重復(fù)。

拿到這樣一個問題,我可能會快速的寫下代碼,這里數(shù)組用ArrayList.

private static void testListSet(){          List<String> arrays = new ArrayList<String>(){              @Override             public boolean add(String e) {                  for(String str:this){                      if(str.equals(e)){                          System.out.println("add failed !!!  duplicate element");                          return false;                      }else{                          System.out.println("add successed !!!");                      }                  }                  return super.add(e);              }          };                  arrays.add("a");arrays.add("b");arrays.add("c");arrays.add("b");          for(String e:arrays)              System.out.print(e);      }

這里我什么都不關(guān),只關(guān)心在數(shù)組添加元素的時候做下判斷(當(dāng)然添加數(shù)組元素只用add方法),是否已存在相同元素,如果數(shù)組中不存在這個元素,就添加到這個數(shù)組中,反之亦然。這樣寫可能簡單,但是面臨龐大數(shù)組時就顯得笨拙:有100000元素的數(shù)組天家一個元素,難道要調(diào)用100000次equal嗎?這里是個基礎(chǔ)。

問題:加入已經(jīng)有一些元素的數(shù)組了,怎么刪除這個數(shù)組里重復(fù)的元素呢?

大家知道java中集合總的可以分為兩大類:List與Set。List類的集合里元素要求有序但可以重復(fù),而Set類的集合里元素要求無序但不能重復(fù)。那么這里就可以考慮利用Set這個特性把重復(fù)元素刪除不就達(dá)到目的了,畢竟用系統(tǒng)里已有的算法要優(yōu)于自己現(xiàn)寫的算法吧。

public static void removeDuplicate(List<People> list){     HashSet<People> set = new HashSet<People>(list);     list.clear();     list.addAll(set);  }   ivate static People[] ObjData = new People[]{      new People(0, "a"),new People(1, "b"),new People(0, "a"),new People(2, "a"),new People(3, "c"),  };
public class People{      private int id;      private String name;            public People(int id,String name){          this.id = id;          this.name = name;      }            @Override     public String toString() {          return ("id = "+id+" , name "+name);      }        }

上面的代碼,用了一個自定義的People類,當(dāng)我添加相同的對象時候(指的是含有相同的數(shù)據(jù)內(nèi)容),調(diào)用removeDuplicate方法發(fā)現(xiàn)這樣并不能解決實際問題,仍然存在相同的對象。那么HashSet里是怎么判斷像個對象是否相同的呢?打開HashSet源碼可以發(fā)現(xiàn):每次往里面添加數(shù)據(jù)的時候,就必須要調(diào)用add方法:

      @Override      public boolean add(E object) {           return backingMap.put(object, this) == null;       }

這里的backingMap也就是HashSet維護(hù)的數(shù)據(jù),它用了一個很巧妙的方法,把每次添加的Object當(dāng)作HashMap里面的KEY,本身HashSet對象當(dāng)作VALUE。這樣就利用了Hashmap里的KEY***性,自然而然的HashSet的數(shù)據(jù)不會重復(fù)。但是真正的是否有重復(fù)數(shù)據(jù),就得看HashMap里的怎么判斷兩個KEY是否相同。

        @Override public V put(K key, V value) {  390         if (key == null) {  391             return putValueForNullKey(value);  392         }  393   394         int hash = secondaryHash(key.hashCode());  395         HashMapEntry<K, V>[] tab = table;  396         int index = hash & (tab.length - 1);  397         for (HashMapEntry<K, V> e = tab[index]; e != null; e = e.next) {  398             if (e.hash == hash && key.equals(e.key)) {  399                 preModify(e);  400                 V oldValue = e.value;  401                 e.value = value;  402                 return oldValue;  403             }  404         }  405   406         // No entry for (non-null) key is present; create one  407         modCount++;  408         if (size++ > threshold) {  409             tab = doubleCapacity();  410             index = hash & (tab.length - 1);  411         }  412         addNewEntry(key, value, hash, index);  413         return null;  414     }

總的來說,這里實現(xiàn)的思路是:遍歷hashmap里的元素,如果元素的hashcode相等(事實上還要對hashcode做一次處理),然后去判斷KEY的eqaul方法。如果這兩個條件滿足,那么就是不同元素。那這里如果數(shù)組里的元素類型是自定義的話,要利用Set的機(jī)制,那就得自己實現(xiàn)equal與hashmap(這里hashmap算法就不詳細(xì)介紹了,我也就理解一點)方法了:

public class People{      private int id; //      private String name;            public People(int id,String name){          this.id = id;          this.name = name;      }            @Override     public String toString() {          return ("id = "+id+" , name "+name);      }           public int getId() {          return id;      }       public void setId(int id) {          this.id = id;      }       public String getName() {          return name;      }       public void setName(String name) {          this.name = name;      }       @Override     public boolean equals(Object obj) {          if(!(obj instanceof People))              return false;          People o = (People)obj;          if(id == o.getId()&&name.equals(o.getName()))              return true;          else             return false;      }            @Override     public int hashCode() {          // TODO Auto-generated method stub          return id;          //return super.hashCode();      }  }

關(guān)于Java中怎么刪除數(shù)組中的重復(fù)元素就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

網(wǎng)頁名稱:Java中怎么刪除數(shù)組中的重復(fù)元素
網(wǎng)頁路徑:http://chinadenli.net/article22/ihjecc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、用戶體驗、域名注冊、網(wǎng)站設(shè)計、移動網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)
视频在线播放你懂的一区| 人妻熟女中文字幕在线| 免费在线观看欧美喷水黄片| 国产欧美韩日一区二区三区| 91亚洲国产成人久久| 国产一区麻豆水好多高潮| 日韩中文字幕欧美亚洲| 大尺度剧情国产在线视频| 国产一区二区三区口爆在线| 在线观看视频国产你懂的| 亚洲精品成人福利在线| 国产精品国产亚洲区久久| 老司机精品视频在线免费看| 国产在线不卡中文字幕| 高清一区二区三区四区五区 | 欧美日韩综合综合久久久| 国产永久免费高清在线精品| 在线播放欧美精品一区| 精品国产91亚洲一区二区三区| 欧美日韩亚洲国产精品| 欧美午夜不卡在线观看| 日本二区三区在线播放| 中国一区二区三区不卡| 91日韩欧美在线视频| 久一视频这里只有精品| 欧美日韩一区二区午夜| 精品少妇人妻av免费看| 国产成人精品一区二三区在线观看| 久热人妻中文字幕一区二区| 久久中文字人妻熟女小妇| 91精品国产综合久久精品 | 欧美大黄片在线免费观看| 尤物久久91欧美人禽亚洲| 国产精品美女午夜视频| 亚洲欧美日韩在线看片| 精品女同在线一区二区| 又黄又硬又爽又色的视频 | 欧美日韩国产成人高潮| 内射精子视频欧美一区二区| 樱井知香黑人一区二区| 日韩高清毛片免费观看|