老生常談的數組去重

狼狼惡狗,記得第一次面試的時候就被問到數組去重的實現方法。如今提供下幾種經常使用的方法。es6

利用hash查找

function unique(arr){
    var result =[],hash = {};
    for (var i = 0,len = arr.length; i<len; i++){
        if(!hash[arr[i]]){
            hash[arr[i]] = true;
            result.push(arr[i])
        }
    }
    return result;
}
複製代碼

利用indexof

function unique(arr){
    var result = []; 
    for(var i=0; i<arr.length; i++){
      if(arr.indexOf(arr[i]) == i){
         result.push(arr[i]);
      }
    }
    return result;
  }
複製代碼
function unique(arr){
    return arr.filter(function (item, index, self) {
        return self.indexOf(item) === index;
    });
}
複製代碼

es6

function unique (arr) {
  return Array.from(new Set(arr))
}

function unique (arr) {
  const seen = new Map()
  return arr.filter((a) => !seen.has(a) && seen.set(a, 1))
}
複製代碼

若有不正確之處,歡迎指出面試

相關文章
相關標籤/搜索