美文网首页
数组去重的三种方式

数组去重的三种方式

作者: 你在我记忆里 | 来源:发表于2016-12-06 10:42 被阅读27次

数组去重的三种方法

前两天面试的时候,面试官出的考题。现在我来总结一下,算是慢慢积累吧

1.两个循环,挨个对比

function uniqueArr(arr) {
        var ret = [],
            length = arr.length;
        for(var i = 0;i < length; i++){
            for(j = i+1; j<length;j++){
                if(arr[i] === arr[j]){
                    j = ++i;
                }
            }
            ret.push(arr[i]);
        }
        return ret;
    }

这种方式应该是可以最容易考虑到的,但是数组过长的话,效率应该会变差。

2.先排序然后用一次循环

function uniqueArr(arr) {
        var sortedArr = arr.sort();
        var results = [];
        for (var i = 0; i < arr.length; i++) {
            if (sortedArr[i + 1] != sortedArr[i]) {
                results.push(sortedArr[i]);
            }
        }
        return results;
    }

排序后用数组后一位比较前一位,一次循环就好了,但是破坏了原有数组的顺序。

3.利用对象字面量的key与value关联性,写起来比较简单

function uniqueArr(arr) {
        var ret = [],
            json = {},
            length = arr.length;

        for(var i = 0; i < length; i++){
            var val = arr[i];
            if(!json[val]){
                json[val] = 1;
                ret.push(val);
            }
        }

        return ret;
    }

也许这种方法想的时候难想到,但是用起来真的很简单~

原文地址:<a href="http://blog.jimliu.xyz/2016/11/21/Template-literals/">Jimliu写字的地方</a>欢迎来踩

相关文章

  • 数组的去重和数组中对象的去重

    数组中对象去重 方式1 jq方式 方式2 原生js方式 普通数组的去重 方式1 普通的数组去重js 方式2 Se...

  • 数组去重的三种方式

    数组去重的三种方法 前两天面试的时候,面试官出的考题。现在我来总结一下,算是慢慢积累吧 1.两个循环,挨个对比 这...

  • 数组去重的几种方式

    上篇我们写到了数组中包含多条对象的去重方式数组中包含多条对象的去重方式,今天我们就写一下普通数组去重吧. 数组去重...

  • 数组去重封装

    上次写到了数组去重的几种方式数组去重的几种方式,那么今天就让我们来封装一下数组去重吧。 就在数组原型上封装吧! 源...

  • 数组去重

    优雅的数组去重方式

  • js中数组去重的三种方法

    数组去重的三种方法: 1、 利用es6中 set类型实现数组去重。 2、 新建一个空数组,然后循环之前的数组,判断...

  • 常用数组去重

    数组去重方式 快速排序

  • JS数组去重方式

    1.ES6去重 2.使用indexOf()方法 3.数组forEach方法 4.添加原型方法

  • 数组去重多重方式

    1. Set(最常用) 2. Map 3. Array.prototype.indexOf() 4.Array.p...

  • js中数组去除重复的元素

    js数组去重 去除数组中重复的元素,用js实现一般来说有三种较常用的方式。 function 1 时间复杂度O(n...

网友评论

      本文标题:数组去重的三种方式

      本文链接:https://www.haomeiwen.com/subject/yytrmttx.html