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

@漏刻有时

相关推荐
angerdream1 分钟前
https://editor.csdn.net/md/?articleId=159120195
javascript·vue.js
敲敲敲敲暴你脑袋8 分钟前
穷鬼快乐AI工具Ollama
javascript·人工智能·ollama
WayneX14 分钟前
Vue 3 + TypeScript + Vite 组件库搭建,自助式生成相应组件文档
前端·javascript·vue.js
贾铭14 分钟前
如何实现一个网页版的剪映(四)使用插件化思维创建pixi绘制画布(转场/滤镜)
前端·javascript
kgduu19 分钟前
js之xml处理
xml·前端·javascript
凌览23 分钟前
尤雨溪新公司官宣!Vite+ 正式开源,前端圈要变天了?
前端·javascript·后端
Highcharts.js29 分钟前
在 Highcharts 中实现 Marimekko可变宽度图|示例教程
javascript·highcharts·图表开发·可视化图表库·可变宽图
是梦终空11640 分钟前
C++中的职责链模式变体
开发语言·c++·算法
mjhcsp1 小时前
C++遗传算法(Genetic Algorithm,GA):进化式全局优化的核心解析
开发语言·c++
吃西瓜的年年2 小时前
前端面试题(vue)
前端·javascript·vue.js