数组去重的四种方法

1.最基本的去重方法

思路:定义一个新数组,并存放原数组的第一个元素,而后将元素组一一和新数组的元素对比,若不一样则存放在新数组中。json

function unique(arr){数组

  var res = [arr[0]];post

  for(var i=1;i<arr.length;i++){测试

    var repeat = false;对象

    for(var j=0;j<res.length;j++){blog

      if(arr[i] == res[j]){排序

        repeat = true;io

        break;function

      }class

    }

    if(!repeat){

      res.push(arr[i]);

    }

  }

  return res;

}

2.先排序在去重

思路:先将原数组排序,在与相邻的进行比较,若是不一样则存入新数组

function unique(arr){

  var arr2 = arr.sort();

  var res = [arr2[0]];

  for(var i=1;i<arr2.length;i++){

    if(arr2[i] !== res[res.length-1]){

      res.push(arr2[i]);

    }

  }

  return res;

}

3.利用对象的属性去重(推荐)

思路:每次取出原数组的元素,而后再对象中访问这个属性,若是存在就说明重复

function unique(arr){

  var res =[];

  var json = {};

  for(var i=0;i<arr.length;i++){

    if(!json[arr[i]]){

      res.push(arr[i]);

      json[arr[i]] = 1;

    }

  }

  return res;

}

4.利用下标查询

  function unique(arr){
     var newArr = [arr[0]];
     for(var i=1;i<arr.length;i++){
    if(newArr.indexOf(arr[i]) == -1){
             newArr.push(arr[i]);
        }
        }
        return newArr;
   }

通过测试以上代码没有什么问题,有问题请指正,谢谢。

相关文章
相关标签/搜索