JS中排除重复元素

使用JAVA中,常常使用Map/Set等集合的containsKey/contains方法以判断是否存在重复元素。

而在JS的数组中并无提供排重方法,而直接在逻辑代码中遍历数组以排重,会增加代码的复杂度。

所以,可以给数组添加一个排重的方法。

 

一、实现方式

1、嵌套循环查找重复元素

在用例开发过程中匆忙间写了一个,用传统的嵌套循环查找是否存在重复元素。

/**
 * 数组是否重复,如重复则返回重复元素
 * @return {}
 */
Array.prototype.isDouble = function() {
    for (var i = 0; i < this.length; i++) {
        for (j = i + 1; j < this.length; j++) {
            if (this[i] && this[j] && this[i] == this[j]) {
                return this[i];
            }
        }
    }
}

 

2、类似HASH算法思路实现

在网上看到一个更好的写法,类似哈希的写法。

/**
 * 数组是否重复,如重复则返回重复元素 
 * @return {}
 */
Array.prototype.isDouble = function() {
    
    var hashObject = {};
    for (var i = 0; i < this.length; i++) {
        
        if (hashObject[this[i]]) {
            return this[i];
        } else {
            hashObject[this[i]] = true;
        }
        
    }
}

 

二、效率

1、简单测试

在IE和Chrome下都做了简单测试,第二种方法比第一种方法快不少。

 

三、附注

1、哈希算法

⑴ 字符串 -> 系列整数 (该整数为hash值,hash值不能逆转为字符串)。

⑵ f(hash值)通过结果值映射到有限的范围内。常用的hash函数为取mod。(除留余数法)

⑶ hash函数映射过程中,往往有可能出现冲突,如两个不同的hash值通过f(n)映射到相同的地址,这时,通常可以为Array的每个元素挂一个链表存放冲突的元素。(链地址法)

 

引用严蔚敏的《数据结构》中的一句话:
……记录的存储位置和它的关键字之间建立一个确定的对应关系f,使每个关键字和结构中一个唯一的存储位置相对应……。我们称这个对应关系f为哈希函数,按这个思想建立的表为哈希表

转载于:https://www.cnblogs.com/nick-huang/archive/2012/11/03/2753084.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值