今天小編給大家分享的是java創(chuàng)建不重復(fù)集合應(yīng)該如何做,相信很多人都不太了解,為了讓大家更加了解java創(chuàng)建不重復(fù)集合的方法,所以給大家總結(jié)了以下內(nèi)容,一起往下看吧。一定會(huì)有所收獲的哦。
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、上猶網(wǎng)絡(luò)推廣、微信平臺(tái)小程序開發(fā)、上猶網(wǎng)絡(luò)營銷、上猶企業(yè)策劃、上猶品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供上猶建站搭建服務(wù),24小時(shí)服務(wù)熱線:18980820575,官方網(wǎng)址:muchs.cnjava怎么創(chuàng)建不重復(fù)的集合?
java中創(chuàng)建不重復(fù)的集合有多種方法,下面我們介紹Java中創(chuàng)建不重復(fù)集合的四種常用方法。
方法一、需要一個(gè)存儲(chǔ)去重后元素的數(shù)組,然后兩層循環(huán),外層遍歷原數(shù)組,內(nèi)容逐個(gè)判斷是否和之后的元素重復(fù),然后再提出來存入新的數(shù)組。
public static Object[] ifRepeat(Object[] arr){ //用來記錄去除重復(fù)之后的數(shù)組長度和給臨時(shí)數(shù)組作為下標(biāo)索引 int t = 0; //臨時(shí)數(shù)組 Object[] tempArr = new Object[arr.length]; //遍歷原數(shù)組 for(int i = 0; i < arr.length; i++){ //聲明一個(gè)標(biāo)記,并每次重置 boolean isTrue = true; //內(nèi)層循環(huán)將原數(shù)組的元素逐個(gè)對(duì)比 for(int j=i+1;j<arr.length;j++){ //如果發(fā)現(xiàn)有重復(fù)元素,改變標(biāo)記狀態(tài)并結(jié)束當(dāng)次內(nèi)層循環(huán) if(arr[i]==arr[j]){ isTrue = false; break; } } //判斷標(biāo)記是否被改變,如果沒被改變就是沒有重復(fù)元素 if(isTrue){ //沒有元素就將原數(shù)組的元素賦給臨時(shí)數(shù)組 tempArr[t] = arr[i]; //走到這里證明當(dāng)前元素沒有重復(fù),那么記錄自增 t++; } } //聲明需要返回的數(shù)組,這個(gè)才是去重后的數(shù)組 Object[] newArr = new Object[t]; //用arraycopy方法將剛才去重的數(shù)組拷貝到新數(shù)組并返回 System.arraycopy(tempArr,0,newArr,0,t); return newArr; }
方法二、只需要?jiǎng)?chuàng)建一個(gè)集合,然后遍歷數(shù)組逐一放入集合,只要在放入之前用contains()方法判斷一下集合中是否已經(jīng)存在這個(gè)元素就行了,然后用toArray轉(zhuǎn)成數(shù)組。
public static void ifRepeat2(Object[] arr){ //創(chuàng)建一個(gè)集合 List list = new ArrayList(); //遍歷數(shù)組往集合里存元素 for(int i=0;i<arr.length;i++){ //如果集合里面沒有相同的元素才往里存 if(!list.contains(arr[i])){ list.add(arr[i]); } } //toArray()方法會(huì)返回一個(gè)包含集合所有元素的Object類型數(shù)組 Object[] newArr = list.toArray(); //遍歷輸出一下測(cè)試是否有效 for(int i=0;i<newArr.length;i++){ System.out.println(" "+newArr[i]); } }
方法三、最簡單的方法就是利用Set集合無序不可重復(fù)的特性進(jìn)行元素過濾。
public static Object[] ifRepeat3(Object[] arr){ //實(shí)例化一個(gè)set集合 Set set = new HashSet(); //遍歷數(shù)組并存入集合,如果元素已存在則不會(huì)重復(fù)存入 for (int i = 0; i < arr.length; i++) { set.add(arr[i]); } //返回Set集合的數(shù)組形式 return set.toArray(); }
方法四、鏈表的哈希集合:有順序,不重復(fù)。
public static void ifRepeat4(Object[] arr){ LinkedHashSet<Object> haoma = new LinkedHashSet<Object>(); for (int i = 0; i < arr.length; i++) { haoma.add(arr[i]); } // 創(chuàng)建迭代器 Iterator<Object> iterator = haoma.iterator(); int a = 0; // 迭代集合 while (iterator.hasNext()) { // true Object c = iterator.next(); System.out.println(c); } }
以上就是java創(chuàng)建不重復(fù)集合應(yīng)該如何做的簡略介紹,當(dāng)然詳細(xì)使用上面的不同還得要大家自己使用過才領(lǐng)會(huì)。如果想了解更多,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道哦!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)頁名稱:java創(chuàng)建不重復(fù)集合應(yīng)該如何做-創(chuàng)新互聯(lián)
文章鏈接:http://muchs.cn/article16/degegg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、商城網(wǎng)站、關(guān)鍵詞優(yōu)化、軟件開發(fā)、外貿(mào)建站、虛擬主機(jī)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容