Javascript 数组去重

数组去重

数组去重,一般需求是给你一个数组,调用去重方法,返回数值副本,副本中没有重复元素。一般来说,两个元素通过 === 比较返回 true 的视为相同元素,需要去重,所以,1 和 "1" 是不同的元素,1 和 new Number(1) 是不同的元素,{} 和 {} 是不同的元素(引用不同)。(当然如果需求认为 {} 和 {} 算作相同的元素,那么解法就不一样了)

method 1

使用两重循环

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

使用两重循环的另外一种比较方式,前面是将原数组的元素和结果数组一一比较,下面我们可以将原数组的重复元素的最后一个元素放入数组中

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;
}

这里还有一个优化的版本

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

  for (var i = 0, len = a.length; i < len; i++) {
    for (var j = i + 1; j < len; j++) {
      // 这一步十分巧妙
      // 如果发现相同元素
      // 则 i 自增进入下一个循环比较
      if (a[i] === a[j])
        j = ++i;    //j = i = i + 1;
    }

    res.push(a[i]);
  }

  return res;
}

method4

用 javascript 中的 object 对象来当作 哈希表

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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Why underscore (觉得这部分眼熟的可以直接跳到下一段了...) 最近开始看 underscore.j...
    韩子迟阅读 5,169评论 0 57
  • 偶然和同事谈到面试的Javascript问题,其中基本上都会有一道问题就是数组去重,随着对于语言深入的学习,这道基...
    IloveData阅读 3,430评论 0 0
  • 话说面试常会碰到面试官会问JavaScript实现数组去重的问题,最近刚好在学习有关于JavaScript数组相关...
    苏星河阅读 3,890评论 0 12
  • 总结一下利用JS解决去重问题的方法。总体思路: 构建一个新的空数组。 遍历数组,将不重复的元素Push到新数组中。...
    Zchao阅读 910评论 0 0
  • 1.简单的循环遍历 最容易想到的方法就是for循环遍历数组,并用indexOf判断是否在数组中已经存在相同的值。 ...
    April_Le阅读 2,833评论 0 1