zoukankan      html  css  js  c++  java
  • js数组去重的三种常用方法总结

    第一种是比较常规的方法

    思路:

    1.构建一个新的数组存放结果

    2.for循环中每次从原数组中取出一个元素,用这个元素循环与结果数组对比

    3.若结果数组中没有该元素,则存到结果数组中


    复制代码 代码如下:

     1 Array.prototype.unique1 = function(){
     2  var res = [this[0]];
     3  for(var i = 1; i < this.length; i++){
     4   var repeat = false;
     5   for(var j = 0; j < res.length; j++){
     6    if(this[i] == res[j]){
     7     repeat = true;
     8     break;
     9    }
    10   }
    11   if(!repeat){
    12    res.push(this[i]);
    13   }
    14  }
    15  return res;
    16 }
    17 var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]
    18 alert(arr.unique1());

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

    思路:

    1.先将原数组进行排序

    2.检查原数组中的第i个元素 与 结果数组中的最后一个元素是否相同,因为已经排序,所以重复元素会在相邻位置

    3.如果不相同,则将该元素存入结果数组中


    复制代码 代码如下:

     1 Array.prototype.unique2 = function(){
     2  this.sort(); //先排序
     3  var res = [this[0]];
     4  for(var i = 1; i < this.length; i++){
     5   if(this[i] !== res[res.length - 1]){
     6    res.push(this[i]);
     7   }
     8  }
     9  return res;
    10 }
    11 var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]
    12 alert(arr.unique2());

    第二种方法也会有一定的局限性,因为在去重前进行了排序,所以最后返回的去重结果也是排序后的。如果要求不改变数组的顺序去重,那这种方法便不可取了。

    第三种方法(推荐使用)

    思路:

    1.创建一个新的数组存放结果

    2.创建一个空对象

    3.for循环时,每次取出一个元素与对象进行对比,如果这个元素不重复,则把它存放到结果数组中,同时把这个元素的内容作为对象的一个属性,并赋值为1,存入到第2步建立的对象中。

    说明:至于如何对比,就是每次从原数组中取出一个元素,然后到对象中去访问这个属性,如果能访问到值,则说明重复。

     1 Array.prototype.unique3 = function(){
     2  var res = [];
     3  var json = {};
     4  for(var i = 0; i < this.length; i++){
     5   if(!json[this[i]]){
     6    res.push(this[i]);
     7    json[this[i]] = 1;
     8   }
     9  }
    10  return res;
    11 }
    12 
    13 var arr = [112,112,34,'你好',112,112,34,'你好','str','str1'];
    14 alert(arr.unique3());
  • 相关阅读:
    ActiveSync合作关系对话框的配置
    WINCE对象存储区(object store)
    Wince 隐藏TASKBAR的方法
    Wince输入法换肤换语言机制
    poj 3080 Blue Jeans 解题报告
    codeforces A. Vasily the Bear and Triangle 解题报告
    hdu 1050 Moving Tables 解题报告
    hdu 1113 Word Amalgamation 解题报告
    codeforces A. IQ Test 解题报告
    poj 1007 DNA Sorting 解题报告
  • 原文地址:https://www.cnblogs.com/libin6505/p/7000293.html
Copyright © 2011-2022 走看看