javascript二维数组(13)数组去重的封装函数

js数组中['指挥大楼', '指挥大楼', '指挥大楼', '指挥大楼'],去重生成新的数组。

  1. 利用字典(或哈希表):这种方法比较适用于需要保持原始顺序的情况。在这种方法中,我们遍历数组,将每个元素作为字典的键,如果元素已经存在则忽略,如果不存在则加入。

JavaScript代码如下:

javascript 复制代码
var uniqueArray = [];
for (var i = 0; i < array.length; i++) {
    if (!dict[array[i]]) {
        dict[array[i]] = true;
        uniqueArray.push(array[i]);
    }
}
  1. 利用双指针:这种方法比较适用于不需要保持原始顺序的情况。这种方法使用两个指针,一个用于遍历数组,另一个用于在去重后的数组中查找插入位置。

JavaScript代码如下:

javascript 复制代码
function removeDuplicates(arr) {
    var i, j, n = arr.length, result = [];
    for (i = 0, j = 0; i < n; i++) {
        while (j < n && arr[j] === arr[i]) j++;
        if (j === n) result.push(arr[i]);
    }
    return result;
}
  1. 利用ES6中的Set对象:Set对象也是一种常用的去重方法,特别是当你需要保持元素的原始顺序时。

JavaScript代码如下:

javascript 复制代码
let array = ['指挥大楼', '指挥大楼', '指挥大楼', '指挥大楼'];
let uniqueArray = [...new Set(array)];
console.log(uniqueArray);  // 输出: ['指挥大楼']

@漏刻有时

相关推荐
比昨天多敲两行8 分钟前
C++11新特性
开发语言·c++
xiaoye-duck22 分钟前
【C++:C++11】核心特性实战:详解C++11列表初始化、右值引用与移动语义
开发语言·c++·c++11
心连欣24 分钟前
解锁对象遍历:当字符串遇上for...in循环
前端·javascript
希望永不加班37 分钟前
SpringBoot 事件机制:ApplicationEvent 与监听器
java·开发语言·spring boot·后端·spring
jstopo网站1 小时前
水厂水泵工作流程图canvas动画
前端·javascript
张元清1 小时前
5 分钟用 Vite SSR 搭建一个全栈 React 应用
前端·javascript·面试
14年ABAP码农1 小时前
ABAP - call API with x-www-form-urlencoded
开发语言
SuniaWang1 小时前
Java 17实战:Record与密封类的黄金搭档
java·开发语言·python
2401_827499991 小时前
python项目实战10-网络机器人03
开发语言·python·php
AIminminHu1 小时前
OpenGL渲染与几何内核那点事-项目实践理论补充(三-1-(3):番外篇-当你的CAD打开“怪兽级”STL时:从内存爆炸到零拷贝的极致优化)
开发语言·c++·线程·多线程