陣列去重的5種方法有哪些?
陣列去重的5種方法:
方法一:
雙重for迴圈去重
原理 兩兩比較如果相等的話就刪除第二個
例如: 1 1 1 3 2 1 2 4
先讓第一個1 即arr[0]與後面的一個個比較 如果後面的值等於arr[0] 刪除後面的值
第一次結束後的結果是 1 3 2 2 4 刪除了後面所有的1
同理 第二次 第三會刪除與自己相同的元素
function noRepeat1(arr){ // 第一層for用來控制迴圈的次數 for(var i=0; i<arr.length; i++){ //第二層for 用於控制與第一層比較的元素 for(var j=i+1; j<arr.length; j++){ //如果相等 if(arr[i] == arr[j]){ //刪除後面的 即第 j個位置上的元素 刪除個數 1 個 arr.splice(j,1); // j--很關鍵的一步 如果刪除 程式就會出錯 //j--的原因是 每次使用splice刪除元素時 返回的是一個新的陣列 // 這意味這陣列下次遍歷是 比較市跳過了一個元素 /* 例如: 第一次刪除後 返回的是 1 1 3 2 1 2 4 * 但是第二次遍歷是 j的值為2 arr[2] = 3 * 相當於跳過一個元素 因此要 j-- * */ j--; } } } return arr; }
方法二:
單層for迴圈
原理和方法一相似
function norepeat(arr){ arr.sort(); //先排序讓大概相同的在一個位置,這裡為什麼說是大概相同 是因為sort排序是把元素當字串排序的 它和可能排成 1 1 10 11 2 20 3 ... 不是我們想要的從小到大 for(var i = 0; i < arr.length-1;i++){ //還是兩兩比較 一樣刪除後面的 if(arr[i]==arr[i+1]){ arr.splice(i,1); //i-- 和j--同理 i--; } } return arr; }
方法三:
原理:用一個空陣列去存首次出現的元素
利用 indexOf 屬性 indexOf是返回某個指定的字元在字串中出現的位置,如果沒有就會返回-1
因此我們可以很好的利用這個屬性 當返回的是 -1時 就讓其存入陣列
function noRepeat2(arr){ var newArr = []; for(var i = 0; i < arr.length; i++){ if(newArr.indexOf(arr[i]) == -1){ newArr.push(arr[i]); } } return newArr; }
方法四:
原理:利用物件的思想,如果物件裡沒有這個屬性的話就會返回undefined
利用這個原理當返回的是undefined時讓其放入陣列然後在給這個屬性賦值
function norepeat3(arr) { var obj = {}; var newArr = []; for(var i = 0; i < arr.length; i++) { if(obj[arr[i]] == undefined) { newArr.push(arr[i]); obj[arr[i]] = 1; } } return newArr; }
方法五:
原理:迴圈比較如果相等的讓後面的元素值為0,最後在輸出的時候刪除為0的這個前提是你的資料裡不能有0,但是凡事可以變通你可以設定任何值替代這個0,這個方法是我當時想到實現的所以沒有進行很好的優化。
var newArr = []; //控制外迴圈 for(var i=0; i<arr.length-1;i++){ //記憶體迴圈 只比較後面的 for(j=i+1;j<arr.length;j++){ //如果相等就讓其值等於0 if(arr[i]==arr[j]){ arr[j]=0; } } //去除值為0的 if(arr[i]==0){ continue; }else{ //放入新的陣列 newArr.push(arr[i]); } }以上就是陣列去重的5種方法有哪些?的詳細內容,更多請關注TW511.COM其它相關文章!