亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長(zhǎng)資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    java怎么創(chuàng)建不重復(fù)的集合?

    java怎么創(chuàng)建不重復(fù)的集合?

    java怎么創(chuàng)建不重復(fù)的集合?

    java中創(chuàng)建不重復(fù)的集合有多種方法,下面我們介紹Java中創(chuàng)建不重復(fù)集合的四種常用方法。

    方法一、需要一個(gè)存儲(chǔ)去重后元素的數(shù)組,然后兩層循環(huán),外層遍歷原數(shù)組,內(nèi)容逐個(gè)判斷是否和之后的元素重復(fù),然后再提出來(lái)存入新的數(shù)組。

        public static Object[] ifRepeat(Object[] arr){           //用來(lái)記錄去除重復(fù)之后的數(shù)組長(zhǎng)度和給臨時(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)記是否被改變,如果沒(méi)被改變就是沒(méi)有重復(fù)元素               if(isTrue){                   //沒(méi)有元素就將原數(shù)組的元素賦給臨時(shí)數(shù)組                   tempArr[t] = arr[i];                   //走到這里證明當(dāng)前元素沒(méi)有重復(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++){               //如果集合里面沒(méi)有相同的元素才往里存               if(!list.contains(arr[i])){                   list.add(arr[i]);               }           }                      //toArray()方法會(huì)返回一個(gè)包含集合所有元素的Object類(lèi)型數(shù)組           Object[] newArr = list.toArray();           //遍歷輸出一下測(cè)試是否有效           for(int i=0;i<newArr.length;i++){               System.out.println(" "+newArr[i]);           }          }

    方法三、最簡(jiǎn)單的方法就是利用Set集合無(wú)序不可重復(fù)的特性進(jìn)行元素過(guò)濾。

    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);           }       }

    (相關(guān)視頻教程分享:java視頻教程)

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)