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);  // 输出: ['指挥大楼']

@漏刻有时

相关推荐
前端小蜗3 分钟前
🌐 利用Chrome内置 【AI翻译 API】实现国际化
前端·javascript·浏览器
怪只怪满眼尽是人间烟火5 分钟前
Linux端口监控脚本
运维·javascript
苏纪云12 分钟前
ES6~ES11新特性
前端·ecmascript·es6
007php00713 分钟前
百度面试题解析:synchronized、volatile、JMM内存模型、JVM运行时区域及堆和方法区(三)
java·开发语言·jvm·缓存·面试·golang·php
阿金要当大魔王~~17 分钟前
uniapp 请求携带数据 \\接口传值 \\ map遍历数据
前端·javascript·uni-app
hey_ner22 分钟前
页面PDF文件格式预览(不使用pdf.js)
前端·javascript
芒果量化31 分钟前
Optuna - 自动调参利器&python实例
开发语言·python·算法·机器学习
over69743 分钟前
JavaScript恋爱物语:当代码学会送花,对象字面量也能当红娘!
javascript
foundbug9991 小时前
基于CSMA-CA协议的V2X通信MATLAB仿真
开发语言·网络·matlab
WangMing_X1 小时前
C#上位机软件:2.5 体验CLR实现多语言混合编程
java·开发语言·c#