JavaScript一次循环判断数组是否有重复元素

今天遇到一个需求,需求是要求判断数组中是否有重复元素。每一个元素都是一个10位的快递单号,但是需求并不要求指出哪个元素重复,仅需给出是否含有重复元素的判断。

第一想法,可能是遍历数组,判断元素是否在剩下的数组元素所组成的数组中有索引

上代码,no code, no die

let array = [1,2,3,4,5,2,5];
for ( let i = 0, length = array.length; i < length ; i++;) {
    if ( array[i].indexOf(array.slice(i++)) != -1) {
        console.log("有重复的")
    }
}

那么大家有没有想过,如果这个重复的元素刚好是数组的最后一个元素,或者说是最后两个元素重复,而这个数组又非常大,那么,如上的做法效率就会非常低。下面上我自己学python和java的时候,在字典和map学到的唯一性的做法,仅供参考,如果你有更好的做法,欢迎共享出来。

let array = [1,2,3,4,5,2,5];
let obj = {}
for ( let i = 0, length = array.length; i < length ; i++;) {
    obj[array[i]] = i;
}
这里是关键,JavaScript中对象的键是唯一性的,所以,我们将数组的值作为对象的键,而对象的索引,作为对象的值,如果数组中有重复的元素,那么,对象中相同值的对象必定会被覆盖,这样,数组中元素的长度,必定不等于对象的长度,由此,可以得到我们的算法

if ( array.length != Object.keys(obj)) {
    console.log("有重复的");
}

怎么样,是不是效率更高了呢,这是必定的。这个思路是从python的字典,以及java中的set和map学来的,如果大家有更好的办法,希望不吝赐教。
我一直在想,能否不循环,就判断数组中是否有相同的值呢?如果能够避免循环,那么对于效率,我相信会是个更高的提升,尤其在大数据的情况下,更加明显.....

如果有更好的算法,我会更新这篇文章。未完待续.....

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,706评论 18 399
  • 道理很多人都懂,但是做到的人有多少?世界上为什么有那么多失败者,而仅有的少数者却那么成功,就是因为他们把所有的道理...
    Elaine雪阅读 1,576评论 0 1
  • 思维导图是一种高效的思维学习工具,能将大脑零散的知识查漏补缺形成一张系统的结构图,高考生想要冲刺分数线?那就试试思...
    一二一思维导图阅读 2,361评论 0 0
  • 1、可是,在真实生活中,与其说恋爱有时间的早晚,不如说恋爱有心态的成熟与否。 正如乐嘉在给女儿的信中写的: 积极的...
    嬉笑怒骂皆生活阅读 2,999评论 0 0
  • 文/墨菲 不管男人还是女人,我们都爱钱又爱美,但往往我们选择的另一半却并不兼具这些,因为面对婚姻和爱钱,人只有尚存...
    写手墨菲阅读 4,659评论 0 1

友情链接更多精彩内容