zoukankan      html  css  js  c++  java
  • js除重的四种方法

    第一种:

    思路:1、构建一个新的数组用于存放结果

       2、for循环原数组,每次从原数组中取出一个新数与结果数组相比较

       3、若结果数组中没有该元素,将该元素push到结果数组

       代码如下:

        var arr = [1,2,3,2,4,2,3,5];

        var arr1 = [];

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

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

            if(arr[i] = arr1[j]){

              break;

            }

          }

          if(arr[i] !==arr1[j]){

            arr1.push(arr[i]);

          }

        }

      console.log(arr1);

    第二种:

      思路:利用indexOf()

      var arr = [1,2,3,2,4,2,3,5];

      var arr1 = [];

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

        if(arr1.indexOf(arr[i])== -1){

          arr1.push(arr[i]);

        }

      }

      console.log(arr1);     

    第三种:for循环遍历数组

      var arr = [1,2,3,2,4,2,3,5];

      var arr1 = [];

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

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

          if(arr[i] == arr[j]){

            i++;//跳出循环

          }

        }

        arr1.push(arr[i]);

      }

      console.log(arr1);

    第四种:先排序,排序之后,相同的会相邻

      var arr = [1,2,3,2,4,2,3,5];

      var arr1 = [];

      var.sort();

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

        if(arr[i] != arr[i+1]){

          arr1.push(arr[i]);

        }

      }

      console.log(arr4);  

      

  • 相关阅读:
    灾备架构图
    Dashboard有什么用
    第一次使用Docker的完整过程
    网页端的消息接收方式
    我理解中的应用架构
    数字化转型模型
    工业4.0的下一个十年
    一文读懂华为全屋智能一文读懂华为全屋智能
    支付总架构解析
    spring boot:shardingsphere+druid整合seata分布式事务(spring boot 2.3.3)
  • 原文地址:https://www.cnblogs.com/lin-f/p/5813217.html
Copyright © 2011-2022 走看看