Javascript 數(shù)組去重

數(shù)組去重

數(shù)組去重,一般需求是給你一個數(shù)組,調(diào)用去重方法,返回數(shù)值副本,副本中沒有重復(fù)元素。一般來說,兩個元素通過 === 比較返回 true 的視為相同元素,需要去重,所以,1 和 "1" 是不同的元素,1 和 new Number(1) 是不同的元素,{} 和 {} 是不同的元素(引用不同)。(當(dāng)然如果需求認(rèn)為 {} 和 {} 算作相同的元素,那么解法就不一樣了)

method 1

使用兩重循環(huán)

function unique(arr) {
    var res = [];
    for(var i = 0, len = arr.length;i < len; i++) {
        var item = arr[i];

        for(var j = 0, jLen = res.length; j<jLen; j++) {
            if(item == res[j]) break;
        }

        if(j == jLen) res.push(item);
    }
    return res;
}

method 2

function unique(arr) {
  var ret = []

  for (var i = 0; i < arr.length; i++) {
    var item = arr[i]
    if (ret.indexOf(item) === -1) {
      ret.push(item)
    }
  }

  return ret
}

這里判斷可以使用一個語法糖

function unique(arr) {
    var res = [];
    for(var i = 0, len = arr.length;i < len; i++) {
        var item = arr[i];
        (res.indexOf(item) === -1) && res.push(item);
    }
    return res;
}

但是在低版本瀏覽器并沒有 indexOf

var indexOf = [].indexOf ?
    function(arr, item) {
      return arr.indexOf(item)
    } :
    function indexOf(arr, item) {
      for (var i = 0; i < arr.length; i++) {
        if (arr[i] === item) {
          return i
        }
      }
      return -1
    }

function unique(arr) {
  var ret = []

  for (var i = 0; i < arr.length; i++) {
    var item = arr[i]
    if (indexOf(ret, item) === -1) {
      ret.push(item)
    }
  }

  return ret
}

method3

使用兩重循環(huán)的另外一種比較方式,前面是將原數(shù)組的元素和結(jié)果數(shù)組一一比較,下面我們可以將原數(shù)組的重復(fù)元素的最后一個元素放入數(shù)組中

function unique(arr) {
    var ret = [];
    var len = arr.length;
    var isRepeat;
    for(var i=0; i<len; i++) {
        isRepeat = false;
        for(var j=i+1; j<len; j++) {
            if(arr[i] === arr[j]){
                isRepeat = true;
                break;
            }
        }
        if(!isRepeat){
            ret.push(arr[i]);
        }
    }
    return ret;
}

這里還有一個優(yōu)化的版本

function unique(a) {
  var res = [];

  for (var i = 0, len = a.length; i < len; i++) {
    for (var j = i + 1; j < len; j++) {
      // 這一步十分巧妙
      // 如果發(fā)現(xiàn)相同元素
      // 則 i 自增進入下一個循環(huán)比較
      if (a[i] === a[j])
        j = ++i;    //j = i = i + 1;
    }

    res.push(a[i]);
  }

  return res;
}

method4

用 javascript 中的 object 對象來當(dāng)作 哈希表

function dedup(arr) {
    var hashTable = {};

    return arr.filter(function(value,index,arr){
        var key = JSON.stringify(value);
        var match = Boolean(hashTable[key]);
        return (match ? false : hashTable[key] = true);
    });
}

因為 Object 的 key 值都是 String 類型,所以對于 1 和 "1" 無法分別,我們可以稍微改進下,將類型也存入 key 中

function dedup(arr) {
    var ret = [];
    var hash = {};

    for(var i = 0; i < arr.length; i++) {
        var item = arr[i];
        var key = typeof(item) + item;
        if(hash[key] !== 1) {
            ret.push(item)
            hash[key] = 1;
        }
    }
    return ret;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Why underscore (覺得這部分眼熟的可以直接跳到下一段了...) 最近開始看 underscore.j...
    韓子遲閱讀 1,417評論 0 57
  • 偶然和同事談到面試的Javascript問題,其中基本上都會有一道問題就是數(shù)組去重,隨著對于語言深入的學(xué)習(xí),這道基...
    IloveData閱讀 552評論 0 0
  • 話說面試常會碰到面試官會問JavaScript實現(xiàn)數(shù)組去重的問題,最近剛好在學(xué)習(xí)有關(guān)于JavaScript數(shù)組相關(guān)...
    蘇星河閱讀 732評論 0 12
  • 總結(jié)一下利用JS解決去重問題的方法??傮w思路: 構(gòu)建一個新的空數(shù)組。 遍歷數(shù)組,將不重復(fù)的元素Push到新數(shù)組中。...
    Zchao閱讀 165評論 0 0
  • 1.簡單的循環(huán)遍歷 最容易想到的方法就是for循環(huán)遍歷數(shù)組,并用indexOf判斷是否在數(shù)組中已經(jīng)存在相同的值。 ...
    April_Le閱讀 406評論 0 1

友情鏈接更多精彩內(nèi)容