JS 前端数据去重

1.使用 for 循环和 indexOf 方法,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  const result = []
  for (let i=0; i<arr.length; i++) {
    let item = arr[i]
    if (result.indexOf(item) === -1) {
      result.push(item)
    }
  }
  return result
}

2.使用 for 循环和对象,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  const result = []
  const obj = {}
  for (let i = 0; i < arr.length; i++) {
    let item = arr[i]
    if (!obj[item]) {
      result.push(item)
      obj[item] = true
    }
  }
  return result
}

3.使用 filter 方法和 indexOf 方法,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  return arr.filter((item, index, arr) => arr.indexOf(item) === index)
}

4.使用 filter 方法和对象,复杂度 O(n)

javascript 复制代码
function uniqueArray(arr) {
  const obj = {}
  return arr.filter((item) => obj.hasOwnProperty(item) ? false : (obj[item] = true))
}

5.使用 Set 数据结构,复杂度 O(n)

javascript 复制代码
function uniqueArray(arr) {
  return Array.from(new Set(arr))
}

// 使用解构 + Set
function uniqueArray(arr) {
  return [...new Set(arr)]
}

6.使用 Map 数据结构,复杂度 O(n)

javascript 复制代码
function uniqueArray(arr) {
  const map = new Map();
  const result = [];
  for (let i = 0; i < arr.length; i++) {
    let item = arr[i]
    if (!map.has(item)) {
      map.set(item, true);
      result.push(item);
    }
  }
  return result;
}

// or
function uniqueArray(arr) {
  const map = new Map();
  return arr.filter(item => !map.has(item) && map.set(item, true););
}

7.使用双重循环和 splice 方法,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  for (var i = 0; i &lt; arr.length; i++) {
    for (var j = i + 1; j < arr.length; j++) {
      if (arr[i] === arr[j]) {
        arr.splice(j, 1);
        j--;
      }
    }
  }
  return arr;
}

8.使用排序和双指针

使用排序和双指针可以实现 O(nlogn) 的时间复杂度。先对数组进行排序,然后使用双指针遍历数组,如果左指针和右指针指向的值相同,就把右指针向右移动,直到找到不同的值,然后把左指针向右移动,继续遍历。

javascript 复制代码
function uniqueArray(arr) {
  arr.sort();
  let left = 0, right = 1;
  let result = [];

  while (right <= arr.length) {
    if (arr[left] === arr[right]) {
      right ++;
    } else {
      result.push(arr[left]);
      left = right;
      right ++;
    }
  }

  return result;
}

9.使用 reduce 方法和 includes,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  return arr.reduce(function(prev, cur) {
    if (!prev.includes(cur)) {
      prev.push(cur);
    }
    return prev;
  }, []);
}

10.使用递归和 includes,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  if (arr.length === 1) {
    return arr;
  } else {
    const first = arr[0];
    const rest = uniqueArray(arr.slice(1));
    return rest.includes(first) ? rest : [first].concat(rest)
  }
}

11.双层循环,复杂度 O(n^2)

javascript 复制代码
function uniqueArray(arr) {
  var result = [];
  for (var i = 0; i < arr.length; i++) {
    for (var j = 0; j < result.length; j++) {
      if (arr[i] === result[j]) {
        break;
      }
    }
    if (j === result.length) {
      result.push(arr[i]);
    }
  }
  return result;
}
相关推荐
threelab14 分钟前
Three.js UV 图像变换效果 | 三维可视化 / AI 提示词
javascript·人工智能·uv
MATLAB代码顾问32 分钟前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
之歆33 分钟前
DAY08_CSS浮动与行内块布局实战指南(下)
前端·css
yqcoder1 小时前
CSS Position 全解析:5 种定位模式详解
前端·css
jinanwuhuaguo1 小时前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
Rhi6371 小时前
从零搭建项目:React 19 + Vite 8 + Tailwind CSS v4 实战配置
前端
竹林8182 小时前
用Viem替代ethers.js:从一次签名失败到完整迁移的实战记录
前端·javascript
之歆2 小时前
DAY08_CSS浮动与行内块布局实战指南(上)
前端·css
有一个好名字2 小时前
工具即双手 —— 从 Bash 到 Tool Dispatch Map
开发语言·chrome·bash
Lyyaoo.2 小时前
优惠券秒杀业务分析
java·开发语言