zoukankan      html  css  js  c++  java
  • JS实现数组去重的6种方法总结

    方法一:

    双层循环,外层循环元素,内层循环时比较值,如果有相同的值则跳过,不相同则push进数组。

     1 Array.prototype.distinct = function(){
     2     var arr = this,result = [],i,j,len = arr.length;
     3     for(i = 0; i < len; i++){
     4         for(j = i + 1; j < len; j++){
     5           if(arr[i] === arr[j]){
     6         j = ++i;
     7        }
     8      }
     9      result.push(arr[i]);
    10   }
    11   return result;
    12 }
    13 var arra = [1,2,3,4,4,1,1,2,1,1,1];
    14 arra.distinct(); //返回[3,4,2,1]    

    方法二:利用splice直接在原数组进行操作
    双层循环,外层循环元素,内层循环时比较值,值相同时,则删去这个值。
    注意删除元素之后,需要将数组的长度也减1.

     1 Array.prototype.distinct = function() {
     2     var arr = this,
     3         i, j, len = arr.length;
     4     for (i = 0; i < len; i++) {
     5         for (j = i + 1; j < len; j++) {
     6             if (arr[i] == arr[j]) {
     7                 arr.splice(j, 1);
     8                 len--;
     9                 j--;
    10             }
    11         }
    12     }
    13     return arr;
    14 };
    15 var a = [1, 2, 3, 4, 5, 6, 5, 3, 2, 4, 56, 4, 1, 2, 1, 1, 1, 1, 1, 1, ];
    16 var b = a.distinct();
    17 console.log(b.toString()); //1,2,3,4,5,6,56

    优点:简单易懂
    缺点:占用内存高,速度慢


    方法三:利用对象的属性不能相同的特点进行去重

     1 Array.prototype.distinct = function() {
     2     var arr = this,
     3         i, obj = {},
     4         result = [],
     5         len = arr.length;
     6     for (i = 0; i < arr.length; i++) {
     7         if (!obj[arr[i]]) { //如果能查找到,证明数组元素重复了
     8             obj[arr[i]] = 1;
     9             result.push(arr[i]);
    10         }
    11     }
    12     return result;
    13 };
    14 var a = [1, 2, 3, 4, 5, 6, 5, 3, 2, 4, 56, 4, 1, 2, 1, 1, 1, 1, 1, 1, ];
    15 var b = a.distinct();
    16 console.log(b.toString()); //1,2,3,4,5,6,56

    方法四:数组递归去重
    运用递归的思想,先排序,然后从最后开始比较,遇到相同,则删除。

     1 Array.prototype.distinct = function() {
     2     var arr = this,
     3         len = arr.length;
     4     arr.sort(function(a, b) { //对数组进行排序才能方便比较
     5         return a - b;
     6     })
     7 
     8     function loop(index) {
     9         if (index >= 1) {
    10             if (arr[index] === arr[index - 1]) {
    11                 arr.splice(index, 1);
    12             }
    13             loop(index - 1); //递归loop函数进行去重
    14         }
    15     }
    16     loop(len - 1);
    17     return arr;
    18 };
    19 var a = [1, 2, 3, 4, 5, 6, 5, 3, 2, 4, 56, 4, 1, 2, 1, 1, 1, 1, 1, 1, 56, 45, 56];
    20 var b = a.distinct();
    21 console.log(b.toString()); //1,2,3,4,5,6,45,56

    方法五:利用indexOf以及forEach

     1 Array.prototype.distinct = function() {
     2     var arr = this,
     3         result = [],
     4         len = arr.length;
     5     arr.forEach(function(v, i, arr) { //这里利用map,filter方法也可以实现
     6         var bool = arr.indexOf(v, i + 1); //从传入参数的下一个索引值开始寻找是否存在重复
     7         if (bool === -1) {
     8             result.push(v);
     9         }
    10     })
    11     return result;
    12 };
    13 var a = [1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 2, 3, 3, 2, 2, 1, 23, 1, 23, 2, 3, 2, 3, 2, 3];
    14 var b = a.distinct();
    15 console.log(b.toString()); //1,23,2,3

    方法六:利用ES6的set
    Set数据结构,它类似于数组,其成员的值都是唯一的。利用Array.from将Set结构转换成数组。

    1 function dedupe(array) {
    2     return Array.from(new Set(array));
    3 }
    4 dedupe([1, 1, 2, 3]) //[1,2,3]

    拓展运算符(...)内部使用for...of循环

    1 let arr = [1,2,3,3];
    2 let resultarr = [...new Set(arr)]; 
    3 console.log(resultarr); //[1,2,3]

    下面给大家补充介绍合并数组并去重的方法

    一、concat()方法
    思路:concat() 方法将传入的数组或非数组值与原数组合并,组成一个新的数组并返回。该方法会产生一个新的数组。

    1 function concatArr(arr1, arr2){
    2   var arr = arr1.concat(arr2);
    3   arr = unique1(arr);//再引用上面的任意一个去重方法
    4   return arr;
    5 }

    二、Array.prototype.push.apply()
    思路:该方法优点是不会产生一个新的数组。

    var a = [1, 2, 3];
    var b = [4, 5, 6];
    Array.prototype.push.apply(a, b);//a=[1,2,3,4,5,6]
      //等效于:a.push.apply(a, b);
      //也等效于[].push.apply(a, b); 
    function concatArray(arr1,arr2){
       Array.prototype.push.apply(arr1, arr2);
         arr1 = unique1(arr1);
         return arr1;
    }
  • 相关阅读:
    第一节 49_ref_out 简单
    第一节 38函数 简单
    第二节 2面向对像简介 简单
    第一节 42字符串基础 简单
    第二节 3属性 简单
    第一节 33enum枚举 简单
    Java jdbc 数据库
    css 使IE和FIREFOX下变为手型
    JS调用PageMethods
    USB设备量产导致通用串行总线控制器显示感叹号解决办法
  • 原文地址:https://www.cnblogs.com/sunyuweb/p/8967282.html
Copyright © 2011-2022 走看看