【工具类】得到多个数组中的相同元素

📝 数组交集实现总结

1. for 循环逐个比较

js 复制代码
function intersection(arrays) {
  let result = arrays[0];
  for (let i = 1; i < arrays.length; i++) {
    result = result.filter(item => arrays[i].includes(item));
  }
  return result;
}

✅ 简单直观,适合新手

❌ 每次 includes 都是 O(n),大数据时性能差


2. reduce + filter(函数式写法)

js 复制代码
function intersection(...arrays) {
  return arrays.reduce((acc, cur) => acc.filter(item => cur.includes(item)));
}

✅ 一行搞定,语法优雅

❌ 和方法 1 性能一样,难理解一点


3. every 检查法

js 复制代码
function intersection(...arrays) {
  let [first, ...rest] = arrays;
  return first.filter(item => rest.every(arr => arr.includes(item)));
}

✅ 逻辑清晰:只要某元素存在于所有数组中就保留

❌ 性能中等,跟 1/2 类似


4. Set 优化

js 复制代码
function intersection(...arrays) {
  return [...arrays.reduce((acc, cur) => 
    new Set([...acc].filter(item => cur.includes(item)))
  )];
}

✅ 用 Set 去重,避免重复元素,查询更快

❌ 还是会用到 includes,性能一般


5. Map 计数统计(推荐大数据量)

js 复制代码
function intersection(...arrays) {
  const countMap = new Map();
  const total = arrays.length;

  for (let arr of arrays) {
    for (let item of new Set(arr)) { // 每个数组去重后再计数
      countMap.set(item, (countMap.get(item) || 0) + 1);
    }
  }

  return [...countMap.entries()]
    .filter(([_, count]) => count === total)
    .map(([item]) => item);
}

✅ 高效,适合处理超大数组(避免反复 includes

✅ 自动去重,不会有重复元素

❌ 写法复杂一些


📊 方法对比表

方法 代码简洁度 性能(小数组) 性能(大数组) 是否去重
for 循环 ⭐⭐⭐ ⭐⭐⭐
reduce+filter ⭐⭐⭐⭐ ⭐⭐⭐
every 检查 ⭐⭐⭐ ⭐⭐⭐
Set 优化 ⭐⭐⭐ ⭐⭐⭐ ⭐⭐
Map 计数 ⭐⭐ ⭐⭐ ⭐⭐⭐⭐

👉 总结:

  • 小数组,简单写 → 方法 1 或 3。
  • 追求优雅 → 方法 2。
  • 避免重复元素 → 方法 4。
  • 大数据量高性能 → 方法 5(Map 计数)。
相关推荐
大飞记Python8 分钟前
【2026更新】Python基础学习指南(AI版)——04数据类型
开发语言·人工智能·python
Alice-YUE1 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
云泽8081 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
froginwe111 小时前
DOM 加载函数
开发语言
Hello eveybody1 小时前
介绍一下背包DP(Python)
开发语言·python·动态规划·dp·背包dp
AI进化营-智能译站2 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust2 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
是上好佳佳佳呀2 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
莎士比亚的文学花园2 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
图码2 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻