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为哈希函数,按这个思想建立的表为哈希表

posted @   nick_huang  阅读(3996)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
点击右上角即可分享
微信分享提示