黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 3種數組去重方法

3種數組去重方法

更新時間:2020-11-02 17:43:05 來源:動力節點 瀏覽1276次

眾所周知,數組(Array)是有序的元素序列,是用于儲存多個相同類型數據的集合。我們其實從開始學習數學的時候就已經慢慢接觸數組這一概念了,然而,在計算機語言中,數組表示把具有相同類型的若干元素按有序的形式組織起來的一種形式。在數組中,有時候難免會有重復的數據,這時候就要用到數組去重了,本文我們就一起來探究一下數組去重方法

總的來說,數組去重其實很簡單,查出數組內的重復數據,然后剔除出去,因此,數組去重方法也有很多種,但都是大同小異:


第一種是比較常規的方法

思路:

1.構建一個新的數組存放結果

2.for循環中每次從原數組中取出一個元素,用這個元素循環與結果數組對比

3.若結果數組中沒有該元素,則存到結果數組中

Array.prototype.unique1 = function(){

var res = [this[0]];

for(var i = 1; i < this.length; i++){

var repeat = false;

for(var j = 0; j < res.length; j++){

if(this[i] == res[j]){

repeat = true;

break;

}

}

if(!repeat){

res.push(this[i]);

}

}

return res;

}

var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]

alert(arr.unique1());


第二種方法比上面的方法效率要高

思路:

1.先將原數組進行排序

2.檢查原數組中的第i個元素 與 結果數組中的最后一個元素是否相同,因為已經排序,所以重復元素會在相鄰位置

3.如果不相同,則將該元素存入結果數組中

Array.prototype.unique2 = function(){

this.sort(); //先排序

var res = [this[0]];

for(var i = 1; i < this.length; i++){

if(this[i] !== res[res.length - 1]){

res.push(this[i]);

}

}

return res;

}

var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]

alert(arr.unique2());

第二種方法也會有一定的局限性,因為在去重前進行了排序,所以最后返回的去重結果也是排序后的。如果要求不改變數組的順序去重,那這種方法便不可取了。


第三種方法(推薦使用)

思路:

1.創建一個新的數組存放結果

2.創建一個空對象

3.for循環時,每次取出一個元素與對象進行對比,如果這個元素不重復,則把它存放到結果數組中,同時把這個元素的內容作為對象的一個屬性,并賦值為1,存入到第2步建立的對象中。

說明:至于如何對比,就是每次從原數組中取出一個元素,然后到對象中去訪問這個屬性,如果能訪問到值,則說明重復。

Array.prototype.unique3 = function(){

var res = [];

var json = {};

for(var i = 0; i < this.length; i++){

if(!json[this[i]]){

res.push(this[i]);

json[this[i]] = 1;

}

}

return res;

}

var arr = [112,112,34,'你好',112,112,34,'你好','str','str1'];

alert(arr.unique3());

第四種方法遍歷數組法

最簡單的去重方法,實現思路:新建一新數組,遍歷傳入數組,值不在新數組就加入該新數組中;

注意點:判斷值是否在數組的方法“indexOf”是ECMAScript5 方法,IE8以下不支持,需多寫一些兼容低版本瀏覽器代碼,源碼如下:

// 最簡單數組去重法

function unique1(array){

var n = []; //一個新的臨時數組

//遍歷當前數組

for(var i = 0; i < array.length; i++){

//如果當前數組的第i已經保存進了臨時數組,那么跳過,

//否則把當前項push到臨時數組里面

if (n.indexOf(array[i]) == -1) n.push(array[i]);

}

return n;

}


以上就是常見的幾種數組去重的方法,其實殊途同歸,最終目的還是為了剔除數組中重復的數據,避免數組的數據重復性。數組在Java基礎中也算是非常重要的內容,本文講的數組去重也只是數組眾多知識點的滄海一粟,想深入學習數組的小伙伴可以觀看本站的Java基礎教程,還有更多的挑戰在等著你!


提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 18成人在线观看 | 日韩精品在线免费观看 | 日韩欧美一区二区三区在线 | 另类在线视频 | 97国产蝌蚪视频在线观看 | h视频免费在线 | 成人深夜视频 | 欧美色精品天天在线观看视频 | 亚洲综合在线另类色区奇米 | 一区二区在线欧美日韩中文 | 丝袜网站在线观看 | 在线观看播放视频www | 69欧美xxxxx色护士视频 | 老司机免费看 | 日韩亚洲制服丝袜中文字幕 | 国产成人在线综合 | 一级美国乱色毛片 | 中文字幕免费在线视频 | 欧美激情一区二区三区免费观看 | 亚洲日本va中文字幕线 | 国产黄色免费在线观看 | 波多野结衣视频在线免费观看 | 免费看黄网 | 亚州视频一区二区 | 亚洲色图图片 | 野花的视频在线观看免费高清 | 日韩麻豆国产精品欧美 | 开心激情综合 | 日韩手机在线 | 欧美在线专区 | 黄色网在线播放 | 欧美亚洲国产一区 | 日韩成人激情 | 日韩高清一区 | 国产做受视频激情播放 | 亚洲精品免费在线视频 | 亚洲福利视频网站 | 第一页在线 | 黄色片视频在线 | 午夜黄视频 | 91精品在线观看视频 |