中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java創建不重復集合應該如何做

發布時間:2020-05-06 13:51:09 來源:億速云 閱讀:1069 作者:小新 欄目:編程語言

今天小編給大家分享的是java創建不重復集合應該如何做,相信很多人都不太了解,為了讓大家更加了解java創建不重復集合的方法,所以給大家總結了以下內容,一起往下看吧。一定會有所收獲的哦。

java怎么創建不重復的集合?

java中創建不重復的集合有多種方法,下面我們介紹Java中創建不重復集合的四種常用方法。

方法一、需要一個存儲去重后元素的數組,然后兩層循環,外層遍歷原數組,內容逐個判斷是否和之后的元素重復,然后再提出來存入新的數組。

    public static Object[] ifRepeat(Object[] arr){  
        //用來記錄去除重復之后的數組長度和給臨時數組作為下標索引  
        int t = 0;  
        //臨時數組  
        Object[] tempArr = new Object[arr.length];  
        //遍歷原數組  
        for(int i = 0; i < arr.length; i++){  
            //聲明一個標記,并每次重置  
            boolean isTrue = true;  
            //內層循環將原數組的元素逐個對比  
            for(int j=i+1;j<arr.length;j++){  
                //如果發現有重復元素,改變標記狀態并結束當次內層循環  
                if(arr[i]==arr[j]){  
                    isTrue = false;  
                    break;  
                }  
            }  
            //判斷標記是否被改變,如果沒被改變就是沒有重復元素  
            if(isTrue){  
                //沒有元素就將原數組的元素賦給臨時數組  
                tempArr[t] = arr[i];  
                //走到這里證明當前元素沒有重復,那么記錄自增  
                t++;  
            }  
        }  
        //聲明需要返回的數組,這個才是去重后的數組  
        Object[]  newArr = new Object[t];  
        //用arraycopy方法將剛才去重的數組拷貝到新數組并返回  
        System.arraycopy(tempArr,0,newArr,0,t);  
        return newArr;  
    }

方法二、只需要創建一個集合,然后遍歷數組逐一放入集合,只要在放入之前用contains()方法判斷一下集合中是否已經存在這個元素就行了,然后用toArray轉成數組。

   public static void ifRepeat2(Object[] arr){  
        //創建一個集合  
        List list = new ArrayList();  
        //遍歷數組往集合里存元素  
        for(int i=0;i<arr.length;i++){  
            //如果集合里面沒有相同的元素才往里存  
            if(!list.contains(arr[i])){  
                list.add(arr[i]);  
            }  
        }  
          
        //toArray()方法會返回一個包含集合所有元素的Object類型數組  
        Object[] newArr = list.toArray();  
        //遍歷輸出一下測試是否有效  
        for(int i=0;i<newArr.length;i++){  
            System.out.println(" "+newArr[i]);  
        }  
  
    }

方法三、最簡單的方法就是利用Set集合無序不可重復的特性進行元素過濾。

public static Object[] ifRepeat3(Object[] arr){  
        //實例化一個set集合  
        Set set = new HashSet();  
        //遍歷數組并存入集合,如果元素已存在則不會重復存入  
        for (int i = 0; i < arr.length; i++) {  
            set.add(arr[i]);  
        }  
        //返回Set集合的數組形式  
        return set.toArray();  
    }

方法四、鏈表的哈希集合:有順序,不重復。

 public static void ifRepeat4(Object[] arr){  
          
        LinkedHashSet<Object> haoma = new LinkedHashSet<Object>();  
        for (int i = 0; i < arr.length; i++) {  
            haoma.add(arr[i]);  
        }  
          
        // 創建迭代器  
        Iterator<Object> iterator = haoma.iterator();  
        int a = 0;  
        // 迭代集合  
        while (iterator.hasNext()) { // true  
            Object c = iterator.next();  
              
            System.out.println(c);  
        }  
    }

以上就是java創建不重復集合應該如何做的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

吉林省| 湟中县| 灵丘县| 定襄县| 登封市| 南阳市| 浦城县| 米泉市| 鄱阳县| 墨玉县| 乌拉特后旗| 鹤庆县| 长顺县| 乌兰县| 景谷| 湾仔区| 西乌珠穆沁旗| 新闻| 绿春县| 大理市| 宣威市| 沙雅县| 盐池县| 会东县| 桐庐县| 宁河县| 文昌市| 长乐市| 务川| 民县| 赤水市| 普陀区| 资源县| 大余县| 常宁市| 诸城市| 七台河市| 芦溪县| 宝兴县| 神木县| 攀枝花市|