Java数组去重的多种方法,[Java教程]JavaScript常见的五种数组去重的方式

[Java教程]JavaScript常见的五种数组去重的方式

0 2016-12-14 15:00:17

▓▓▓▓▓▓ 大致介绍

JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结

先来建立一个数组var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN];

▓▓▓▓▓▓ 第一种

思路:建立一个临时数组,用for循环去依次判断arr中的每个项在临时数组中是否有相同的值,如果没有则将这个值添加到临时数组,如果有相同的值则不添加,最后返回这个临时数组

代码:1 Array.prototype.removeDuplicate = function(){ 2 var n = []; 3 for(var i=0;i

注意:不会去掉重复的NaN值

▓▓▓▓▓▓ 第二种

思路:建立一个临时数组,用for循环利用indexOf()方法去依次判断arr中的每个项在arr中第一次出现的位置,如果这个项在arr中第一次出现的位置就是它的位置,表明在它之前没有相同的值则把它添加到临时数组中,如果这个项在arr中第一次出现的位置不是他的位置则表明在它之前有相同的值,则不把他添加到临时数组中;最后返回临时数组

代码:1 Array.prototype.removeDuplicate = function(){ 2 var n = []; 3 for(var i=0;i

注意:会把NaN值删除

▓▓▓▓▓▓ 第三种

思路:建立一个临时对象,利用for循环检测这个临时对象有没有arr[i]这个属性,如果没有这个属性表明arr[i]在它之前没有和它重复的值。把临时对象的arr[i]属性设置为true,表明有这个属性并把这个项添加到临时数组中;最后返回临时数组

代码:1 Array.prototype.removeDuplicate = function(){ 2 var n = [],m = {}; 3 for(var i=0;i

▓▓▓▓▓▓ 第四种

思路:先将这个数组排序,然后比较每个项和它后面的项的值是否相等,如果不相等则添加到临时数组中;最后返回临时数组

代码:1 Array.prototype.removeDuplicate = function(){ 2 var n = []; 3 this.sort(); 4 for(var i=0;i

注意:不会去掉重复的NaN值

▓▓▓▓▓▓ 第五种

思路:利用ES6的方法set方法去重,并用Array.from转换为数组

set是一种新的数据结构,它可以接收一个数组或者是类数组对象,自动去重其中的重复项目,返回一个对象

代码:1 Array.prototype.removeDuplicate = function(){2 return (Array.from(new Set(this)));3 }4 var m = arr.removeDuplicate();5 console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

本文网址:http://www.shaoqun.com/a/269063.html

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:admin@shaoqun.com。

JavaScript

0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值