这次给大家带来JS数组去重最快的算法,JS数组去重的注意事项有哪些,下面就是实战案例,一起来看一下。
在JS中经常会遇到去除数组中重复数据的需求,在此介绍四种算法以实现JS数组去重的功能.
1. 速度最快算法:对象键值对法
实现思路:新建一js对象以及新数组,遍历传入数组时,判断值是否为js对象的键,不是的话给对象新增该键并放入新数组。
- //注意点: 判断 是否为js对象键时,会自动对传入的键执行“toString()”,不同的键可能会被误认为一样;例如: a[1]、a["1"] 。解决上述问题还是得调用“indexOf”。//速度最快, 占空间最多(空间换时间)function unique(array){ var n = {}, r = [], len = array.length, val, type; for (var i = 0; i < array.length; i++) { val = array[i]; type = typeof val; if (!n[val]) { n[val] = [type]; r.push(val); } else if (n[val].indexOf(type) < 0) { n[val].push(type); r.push(val); } } return r;}//测试代码:var arr=[1,2,3,4,5,29,5,3,1,2];var rel=unique(arr);console.log(rel);
登录后复制
运行结果:
2.最巧妙算法:优化遍历数组法
实现思路:获取没重复的最右一值放入新数组。(检测到有重复值时终止当前循环同时进入顶层循环的下一轮判断)
- function unique1(array){ var r = []; for(var i = 0, l = array.length; i<l; i++){ for(var j = i + 1; j < l; j++) if(array[i] == array[j]) j == ++i; r.push(array[i]); } return r;}//测试代码:var arr=[1,2,3,4,5,29,5,2];var rel=unique1(arr);console.log(rel);
登录后复制
运行结果:
3.算法:排序后相邻去除法
实现思路:给传入数组排序,排序后相同值相邻,然后遍历时新数组只加入不与前一值重复的值。
- //将相同的值相邻,然后遍历去除重复值function unique2(array){ array.sort(); var re=[array[0]]; for(var i = 1; i < array.length; i++){ if( array[i] !== re[re.length-1]) { re.push(array[i]); } } return re;}//测试代码:var arr=[1,2,3,4,5,29,5,2,3,1];var rel=unique2(arr);console.log(rel);
登录后复制
运行结果:
4.算法:数组下标判断法
实现思路:如果当前数组的第i项在当前数组中第一次出现的位置不是i,那么表示第i项是重复的,忽略掉。否则存入结果数组
- function unique3(array){ var n = [array[0]]; //结果数组 //从第二项开始遍历 for(var i = 1; i < array.length; i++) { //如果当前数组的第i项在当前数组中第一次出现的位置不是i, //那么表示第i项是重复的,忽略掉。否则存入结果数组 if (array.indexOf(array[i]) == i) n.push(array[i]); } return n;}//测试代码:var arr=[1,2,3,4,5,29,3,4,2,5,1];var rel=unique3(arr);console.log(rel);
登录后复制
相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!
推荐阅读:
JS去除数组中重复项的方法
bootstrap响应式导航条模板应如何使用
vue.js操作数组数据的方法
以上就是JS数组去重最快的算法的详细内容,更多请关注【创想鸟】其它相关文章!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。