数组去重的N种方法

  1. 不需要开辟新的数组空间,可以实现去重
<script>
        var arr=[1,2,3,4,5,1,3,4,6,7];
        for(let i=0;i<arr.length-1;i++){
            let item=arr[i],
                ary=arr.slice(i+1);
            if(ary.indexOf(item)>-1){
                arr.splice(i,1);
                i--;
            }
        }
        console.log(arr);
    </script>
<script>
        var arr=[1,2,3,4,5,1,3,4,6,7];
        for(let i=0;i<arr.length-1;i++){
            let item=arr[i],
                ary=arr.slice(i+1);
            if(ary.indexOf(item)>-1){
               arr[i]=null;
            }
        }
        arr=arr.filter(item=>item!==null);
        console.log(arr);
    </script>
  1. 键值对的方式
<script>
        var arr=[1,2,3,4,5,1,3,4,6,7];
        let obj={};
        for(let i=0;i<arr.length;i++){
            let item=arr[i];
            if(typeof obj[item]!=="undefined"){
                arr[i]=arr[arr.length-1];
                arr.length--;
                i--;
            }
            obj[item]=item;
        }
        obj=null;
        console.log(arr);
    </script>
  1. 使用双for循环进行去重
<script>
    let arr=[1,2,2,3,4,5,1,2,4,5,2,4];
    for(let i=0;i<arr.length-1;i++){
        let item=arr[i];
        for(let j=i+1;j<arr.length;j++){
            if(item==arr[j]){
                // 用最后一项替换当前项
                arr[j]=arr[arr.length-1];
                //最后一项删掉
                arr.pop();
                //下一轮还和这一项比(因为这一项已经变为最新的最后一项了)
                j--;
            }
        }
    } 
    console.log(arr);
</script>
  1. ES6中使用set
<script>
    let arr=[1,2,2,3,4,5,1,2,4,5,2,4];
    arr=Array.from(new Set(arr));
    console.log(arr);
</script>

  1. 数组排好序,进行去重
 <script>
        var arr=[1,2,3,4,5,1,3,4,6,7];
        arr.sort((a,b)=>a-b);
        arr=arr.join('@')+'@';
        let reg=/(\d+@)\1*/g;
        ary=[];
        arr.replace(reg,(value,group1)=>{
            ary.push(parseFloat(group1));
        })
        console.log(ary);
    </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值