热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

js数组去重复项的五种方法比较

第一种:耗时最长,用了双重循环Array.prototype.unique1function(){varrnewArray();label:fo

第一种:耗时最长,用了双重循环

Array.prototype.unique1 = function () {
var r = new Array();
label:for(var i = 0, n = this.length; i for(var x = 0, y = r.length; x if(r[x] == this[i]) {
continue label;
}
}
r[r.length] = this[i];
}
return r;
}

第二种:用了正则表达式

Array.prototype.unique2 = function () {
return this.sort().join(",,").replace(/(,|^)([^,]+)(,,\2)+(,|$)/g,"$1$2$4").replace(/,,+/g,",").replace(/,$/,"").split(",");
}

第三种:用了hasOwnProperty

Array.prototype.unique3 = function() {
var temp = {}, len = this.length;
for(var i=0; i var tmp = this[i];
if(!temp.hasOwnProperty(tmp)) {
temp[this[i]] = "my god";
}
}

len = 0;
var tempArr=[];
for(var i in temp) {
tempArr[len++] = i;
}
return tempArr;
}

第四种:先排序,再比较相邻的

Array.prototype.unique4 = function () {
var temp = new Array();
this.sort();
for(i = 0; i if( this[i] == this[i+1]) {
continue;
}
temp[temp.length]=this[i];
}
return temp;

}

第五种:用了hash,耗时最短

Array.prototype.unique5 = function() {
var result=[], hash={};
for(var i=0;i if(!hash[this[i]]){
result.push(this[i]);
hash[this[i]]=true;
}
}
return result;
}

测试方法:

function testArr(){
var arr=[];
for(var i=0;i<100000;i++){
arr.push(i);
}
var d1=new Date().getTime();
arr.unique1();
console.log("unique1:执行了 "+(new Date().getTime()-d1)+" ms");
//unique1:执行了 4516 ms
d1=new Date().getTime();
arr.unique2();
console.log("unique2:执行了 "+(new Date().getTime()-d1)+" ms");
//unique2:执行了 153 ms
d1=new Date().getTime();
arr.unique3();
console.log("unique3:执行了 "+(new Date().getTime()-d1)+" ms");
//unique3:执行了 60 ms
d1=new Date().getTime();
arr.unique4();
console.log("unique4:执行了 "+(new Date().getTime()-d1)+" ms");
//unique4:执行了 95 ms
d1=new Date().getTime();
arr.unique5();
console.log("unique5:执行了 "+(new Date().getTime()-d1)+" ms");
//unique5:执行了 16 ms
}
testArr();
借鉴于: js数组去重复项


方法五原理:

我们可以 用一个hashtable的结构(采用的是数据结构中所说的链地址法处理冲突的方法)记录已有的元素,这样就可以避免内层循环。

恰好,在Javascript中实现hashtable是很简单(Javascript中允许任意对象作为下标,使的Object可以有任意的key做为属性),改进如 下:



推荐阅读
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • Java程序设计第4周学习总结及注释应用的开发笔记
    本文由编程笔记#小编为大家整理,主要介绍了201521123087《Java程序设计》第4周学习总结相关的知识,包括注释的应用和使用类的注释与方法的注释进行注释的方法,并在Eclipse中查看。摘要内容大约为150字,提供了一定的参考价值。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文介绍了获取关联数组键的列表的方法,即使用Object.keys()函数。同时还提到了该方法在不同浏览器的支持情况,并附上了一个代码片段供读者参考。 ... [详细]
author-avatar
博艺
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有