zoukankan      html  css  js  c++  java
  • 数组去重的几种方法

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <script>
      
      //第一种
      function uniq(array){
        var temp = []; //一个新的临时数组
        for(var i = 0; i < array.length; i++){
            if(temp.indexOf(array[i]) == -1){
                temp.push(array[i]);
            }
        }
           return temp;
        }
        var aa = [1,2,2,4,9,6,7,5,2,3,5,6,5];
        console.log(uniq(aa));
       
       
       //第二种
    function uniq1(array){
        var temp = [];
        var index = [];
        var l = array.length;
        for(var i = 0; i < l; i++) {
            for(var j = i + 1; j < l; j++){
              console.log(array[i],array[j])
                if (array[i] === array[j]){
                    i++;
                    j = i;
                }
            }
            temp1.push(array[i]);
            index.push(i);
        }
        console.log(index);
        return temp1;
    }
    
    var aa = [1,2,2,3,5,3,6,5];
    console.log(uniq1(aa));
    
    
    //第三种
    function unique3 (arr) {
      return Array.from(new Set(arr))
    }
    var arr = [55,66,77,77,88,88,99];
    console.log(unique3(arr))
    var arr1 = [554,66,77,77,88,88,99];
    console.log(...new Set(arr1))
     //第三种  es6中的set方法
    let arr2 = [1,2,3,4,5,6,7,8,9]
    let set = new Set(arr2)
    console.log(Array.from(set))
    
    
    //第四种 
    function noRepeat1(arr3){
      // 第一层for用来控制循环的次数
      for(var i=0; i<arr3.length; i++){
          //第二层for 用于控制与第一层比较的元素
          for(var j=i+1; j<arr3.length; j++){
              //如果相等
              if(arr3[i] == arr3[j]){
                  //删除后面的 即第 j个位置上的元素  删除个数 1 个
                  arr3.splice(j,1);
                  // j--很关键的一步  如果删除 程序就会出错 
                  //j--的原因是 每次使用splice删除元素时 返回的是一个新的数组 
                  // 这意味这数组下次遍历是 比较市跳过了一个元素
                  /*
                      例如: 第一次删除后 返回的是 1 1 3 2 1 2 4
                    *  但是第二次遍历是 j的值为2  arr[2] = 3
                    *  相当于跳过一个元素 因此要 j--
                    * */
                  j--;
    
              }
    
          }
      }
    
      return arr3;
        }
        var bb = [1,1,1,3,5,3,6,5];
      console.log(noRepeat1(bb))
      
    
    
    
    //第五种
    function noRepeat(arr){
        arr.sort();
        //先排序 从小到大排序 
        for(var i = 0; i < arr.length-1;i++){
    //两个进行比较 一样删除后面的
            if(arr[i]==arr[i+1]){
                arr.splice(i,1);
                //i-- 和j--同理
                i--;
            }
        }
        return arr;  
    }
    
    var bbd = [1,8,1,3,5,8,6,5];
      console.log(noRepeat(bbd))
      </script>
    </body>
    
    </html>
  • 相关阅读:
    JavaScript事件的几个细节
    CSS选择器从右向左的匹配规则
    JavaScript原型与继承
    CSS3制作ajax loader icon
    jQuery之.on()方法
    Special Resource Operator (SRO)
    openness configure dns server
    add dns items for coredns
    深入理解linux nat
    tcpdump for container
  • 原文地址:https://www.cnblogs.com/toughy/p/11283360.html
Copyright © 2011-2022 走看看