首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
宝塔
V2EX  ›  JavaScript

数组去重

  •  
  •   wenjay · 120 天前 · 3663 次点击
    这是一个创建于 120 天前的主题,其中的信息可能已经有所发展或是发生改变。

    数组去重

     Array.prototype.unique1 = function () {
       var n = []; //一个新的临时数组
       for (var i = 0; i < this.length; i++) //遍历当前数组
       {
         if (n.indexOf(this[i]) == -1) n.push(this[i]);
       }
       return n
    }
    
    第 1 条附言  ·  120 天前
    面试老喜欢问这个
    征集下高级(装逼)回答,可以纵观发展历史、性能、工具又不太啰嗦。👻

    目前已知的高级回答:时间复杂度为 O(n^2),空间复杂度为 O(n)😂
    49 回复  |  直到 2019-07-23 09:13:03 +08:00
        1
    zhao7399686   120 天前
    ?
        2
    NewDraw   120 天前 via Android
    这代码是在养蛊啊!
        3
    AlloVince   120 天前   ♥ 5
    ``` js
    Array.from(new Set(inputArray));
    ```
        4
    wenjay   120 天前
    发出去的文章不能修改的吗?
        5
    wunonglin   120 天前
        6
    wenjay   120 天前
    @AlloVince ES6 就是如此简单,不过面试老喜欢问这个问题,要如何回答才能显得高级呢😂
        7
    Yumwey   120 天前
    用 filter 一行就写完了
        8
    starsriver   120 天前 via Android
    es6 new 的 array 自动去重。
        9
    wenjay   120 天前
        10
    lihongjie0209   120 天前
    数据结构没学好?
        11
    xingyue   120 天前
    我这是要完犊子了吗,看了半天没觉得有什么问题.....除了代码啰嗦了点。再看看 #1 #2 #10,现在内心慌的一.....
        12
    taogen   120 天前 via Android
    就说算法的时间复杂度为 O(n^2),空间复杂度为 O(n)。高级否?
        13
    taogen   120 天前 via Android
    另外,用 hash table 作为中间容器,时间复杂度可以为 O(n)
        14
    oIMOo   120 天前
    转成 set 再转回 list 怎么样?
        15
    lynnic   120 天前 via Android
    时间复杂度为啥是 n 方?
        16
    necomancer   120 天前
    @lynnic indexof 是 o(n) 的吧
        17
    kyuuseiryuu   120 天前 via iPhone
    @necomancer 外面还有一层 n🤣
        18
    serenader   120 天前   ♥ 2
    LZ 的这个方法有个 bug,无法去重 NaN 以及 {} 。

    几年前我写过一篇文章,也是讲去重的:blog.serenader.me/javascript-shu-zu-qu-zhong/

    不过刚刚看了一下,我文章里面最后给出的方案也有 bug。。纯粹当抛砖引玉了,看看大家能找到几个 bug 🤣🤣
        19
    indomi   120 天前
    [...new Set(arr)]
        20
    bumz   120 天前 via iPhone
    ES6 之前就手写一哈希表,高级吗,手动狗头
        21
    15651980765   119 天前
    @Yumwey 请问用 filter 是这样吗?
    Array.prototype.unique = function() {
    return this.filter(function(item, index, array) {return array.indexOf(item) === index});
    }
    我测了一下这种方法在数组很长( 4000w+)的情况下,耗时差不多是楼主方法的两倍。
    Array.from(new Set(array))这种比楼主的方法稍微快一点
        22
    stillsilly   119 天前
    let a = [1,1,2,2,2,3,3]
    let b = [...new Set(a)]
    console.log(b)
        23
    imbacc   119 天前
    后排吃瓜
        24
    karllynn   119 天前
    用 hash 的话,数组的顺序会变的…楼主这个时间复杂度太高了
        25
    QiaTia   119 天前
    ```
    Array.prototype.unique1 = function () {
    var n = {}; //一个新的临时数组
    for (var i = 0; i < this.length; i++) //遍历当前数组
    {
    if (n.[this[i]] !== 'a') n[this[i]]='a'
    }
    return Object.keys(n)
    }
    ```
        26
    QiaTia   119 天前
    @QiaTia 多打了一个点 if (n[this[i]] !== 'a')
        27
    dartabe   119 天前
    之前在写 leetcode 的时候用的 set 做的中间容器. 时间复杂度 O(n)

    后来发现 set 自动就可以去重了
        28
    dartabe   119 天前
    不过 javascript 对象直接就是哈希表了? 用 set 的话我只是懒得存 1/0 或者 true /false

    求大佬看我理解对不对
        29
    weixiangzhe   119 天前 via iPhone
    这种东西 直接看 lodash 源码最靠谱了
        30
    reus   119 天前
    把 indexOf 改成对 Set 的操作,用 Set 辅助去重
    如果没有 Set,那就自己实现一个
        31
    CodingNaux   119 天前 via iPhone
    unique ( collection,func)
        33
    RoshanWu   119 天前
        34
    wozhizui   119 天前
    @oIMOo 俺也一样
        35
    Arizas   119 天前
    uniqueResult = [...new Set(arr)]
        36
    Aoerz   119 天前 via Android
    首先排序,然后遍历,时间复杂度 O(n),空间复杂度 O(1)
        37
    Snail233   119 天前
    es6 不是有 set 么、
        38
    lihongjie0209   119 天前   ♥ 3
    @Aoerz
    排序的 nlogn 的时间复杂度不算了?
        39
    Fairy1128   119 天前
    难道不是先问 数组的 item 是普通类型还是引用类型吗
        40
    Laumm   119 天前
    @Aoerz 既然都需要排序了,时间复杂度就应该大于 O(n)
        41
    Laumm   119 天前
    感觉最简单就是放 Set 里了
        42
    arnoldxiao   119 天前
    用 Set 含一下再放回去
        43
    fengdechoulian   119 天前
    @arnoldxiao 仰望高端玩家
        44
    doing1   119 天前
    我服了
        45
    Aoerz   119 天前 via Android
    @Laumm 是的,把排序这茬给忘了
        46
    DRcoding   119 天前
    所谓的 filter
    var r = ['aa','bb','cc','bb'].filter(function (ele, index, self) {
    return self.indexOf(ele) === index;
    });
    console.log(r.toString());
        47
    ChiangDi   119 天前 via iPhone
    不能先排序吧,数组里可能有数字可能有字符串或者其它任何东西
        48
    YouMoeYi   119 天前
    为啥不用 Set
    function arr_dr (arr){
    let st = new Set(arr);
    return [...st];
    }
        49
    mystorp   116 天前
    Array.prototype.unique1 = function () {
    let m = new Map;
    for (var i = 0; i < this.length; i++) //遍历当前数组
    {
    // 不同于 {}, Map 是有序的哈希表
    // Map 的 key 可以是任意 js 值
    m.set(this[i], true);
    }
    return m.keys();
    }

    let arr = [1, 1, 2, 2, NaN, NaN, null, null, undefined, undefined, {}, [], Symbol.split, '', '', false, false];
    console.log(arr.unique1());
    // MapIterator { 1, 2, NaN, null, undefined, {}, [], Symbol(Symbol.split), '', false }
    arr.push(arr.shift(), arr.shift());
    console.log(arr.unique1());
    // MapIterator { 2, NaN, null, undefined, {}, [], Symbol(Symbol.split), '', false, 1 }
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   2095 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 28ms · UTC 01:52 · PVG 09:52 · LAX 17:52 · JFK 20:52
    ♥ Do have faith in what you're doing.