js数组去重的三种常用方法总结

news/2024/7/19 14:03:57 标签: js, 数组去重

第一种是比较常规的方法

思路:

1.构建一个新的数组存放结果

2.for循环中每次从原数组中取出一个元素,用这个元素循环与结果数组对比

3.若结果数组中没有该元素,则存到结果数组中

复制代码代码如下:

Array.prototype.unique1 = function(){
 var res = [this[0]];
 for(var i = 1; i < this.length; i++){
  var repeat = false;
  for(var j = 0; j < res.length; j++){
   if(this[i] == res[j]){
    repeat = true;
    break;
   }
  }
  if(!repeat){
   res.push(this[i]);
  }
 }
 return res;
}
var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]
alert(arr.unique1());

第二种方法比上面的方法效率要高

思路:

1.先将原数组进行排序

2.检查原数组中的第i个元素 与 结果数组中的最后一个元素是否相同,因为已经排序,所以重复元素会在相邻位置

3.如果不相同,则将该元素存入结果数组中

复制代码代码如下:

Array.prototype.unique2 = function(){
 this.sort(); //先排序
 var res = [this[0]];
 for(var i = 1; i < this.length; i++){
  if(this[i] !== res[res.length - 1]){
   res.push(this[i]);
  }
 }
 return res;
}
var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]
alert(arr.unique2());

第二种方法也会有一定的局限性,因为在去重前进行了排序,所以最后返回的去重结果也是排序后的。如果要求不改变数组的顺序去重,那这种方法便不可取了。

第三种方法(推荐使用)

思路:

1.创建一个新的数组存放结果

2.创建一个空对象

3.for循环时,每次取出一个元素与对象进行对比,如果这个元素不重复,则把它存放到结果数组中,同时把这个元素的内容作为对象的一个属性,并赋值为1,存入到第2步建立的对象中。

说明:至于如何对比,就是每次从原数组中取出一个元素,然后到对象中去访问这个属性,如果能访问到值,则说明重复。

复制代码代码如下:

Array.prototype.unique3 = function(){
 var res = [];
 var json = {};
 for(var i = 0; i < this.length; i++){
  if(!json[this[i]]){
   res.push(this[i]);
   json[this[i]] = 1;
  }
 }
 return res;
}

var arr = [112,112,34,'你好',112,112,34,'你好','str','str1'];
alert(arr.unique3());


http://www.niftyadmin.cn/n/1599256.html

相关文章

串行接口

;************************; ;*8251串行通讯(自发自收)*; ;************************; data segment io8253a equ 280h io8253b equ 283h io8251a equ 2b8h io8251b equ 2b9h mes1 db you can play a key on the keybord!,0dh,0ah,24h mes2 dd mes1 data ends code segment ass…

停止oracle的job

1. 首先确定要停止的JOB号在10g中可通过Dba_Jobs_Running进行确认。2. Broken你确认的JOB注意使用DBMS_JOB包来标识你的JOB为BROKEN。SQL> EXEC DBMS_JOB.BROKEN(job#,TRUE);注意&#xff1a;当执行完该命令你选择的这个JOB还是在运行着的。3. Kill 对应的Oracle Session应为…

sap清账使用反记账_SAP学习基础篇(41):FI模块-应付账款(四)

想看文章合集请点击这里&#xff1a;热心市民小王&#xff1a;SAP学习基础篇合集&#xff08;不定期持续更新&#xff09;​zhuanlan.zhihu.com41、应付账款&#xff08;四&#xff09;41.1 供应商预付账款如图输入以下参数在“VENDOR”界面输入以下参数在“Bank”界面输入以下…

存储过程遍历游标三种方式

CREATE OR REPLACE PROCEDURE PRC_LJ IS CURSOR C_EMP IS --声明显式游标 SELECT EMPNO,ENAME FROM EMP; C_ROW C_EMP%ROWTYPE; --定义游标变量&#xff0c;该变量的类型为基于游标C_EMP的记录 BEGIN --For 循环 FOR C_ROW IN C_EMP LOOP DBMS_OUT…

html在web属于哪个分层_高血压有3级4层,低危、中危、高危、很高危,你到底属于哪种?...

《中国高血压防治指南&#xff08;2018年修订版&#xff09;》数据显示&#xff1a;2012年~2015年&#xff0c;中国18岁以上的居民高血压患病粗率是27.9%。也就是说&#xff0c;10个人里面&#xff0c;将近有3个人是高血压患者。实际上&#xff0c;我国高血压患者的知晓率较低&…

知识图谱属性融合_肖仰华教授讲授【知识图谱概念与技术】研讨实录(六)

文章来源于微信公众号&#xff1a;知识工场&#xff08;ID&#xff1a;fudankw&#xff09;原文链接&#xff1a;请点击文章仅用于学习交流&#xff0c;如有侵权请联系删除以下为课程第六章《百科图谱构建》的研讨内容&#xff1a;1、百科图谱的意义体现在哪些方面&#xff1f;…

spring 定时任务的 执行时间设置规则

单纯针对时间的设置规则 org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间&#xff0c;只需要设置其cronExpression属性。 一个cronExpression表达式有至少6个&#xff08;也可能是7个&#xff09;由空格分隔的时间元素。从左至右&…

三层注册+VB.net实现

最近几天设计模式放了放&#xff0c;看了一套关于三层的视频&#xff0c;关于三层架构在VS中怎么实现登录&#xff0c;自己做了一下&#xff0c;下面是注意事项&#xff0c;以及步骤和代码。 第一步&#xff1a; 搭建环境 创建窗体 搭建三层&#xff1a; 新建解决方案 模…