哈希表数组去重

方式1:使用shift()获取并删除删除数组的第一个元素,判断这个元素是否还存在于数组中,如果存在则说明这个元素的是重复的;如果不存在,进行push()操作

function unique(a){
    if(Array.isArray(a)){ var len = a.length,item; while(len--){ item = a.shift(); if(a.indexOf(item) === -1){ a.push(item); } } } return a; }

方式2:建立一个哈希表,通过对象属性查询去除重复元素

function unique(array){
    var hash = {}, len = array.length, result = [], i; for(i = 0; i < len; i++){ if(!hash[a[i]]){ hash[a[i]] = true; result.push(a[i]); } } return result; }

方式3:思路和方式2类似,但是简洁很多

 
function unique(arr) {
    var hash = {}; return arr.filter(function (n) { hash[n] = (hash[n] || 0); return (++hash[n] <= 1); }); }

转载于:https://www.cnblogs.com/leolovexx/p/6802332.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值