【算法复习】哈希|Map 与 Set 两个高频套路

一、 前端武器库:Object vs Map vs Set

在 JavaScript 中,实现哈希表有三种原生数据结构。在算法题中,请严格遵循以下选型直觉:

  1. Set (集合)

    • 核心特征:自带去重机制,只有键(或者说键值合一)。
    • 适用场景 :只关心元素存不存在、不需要记录额外信息、需要极速去重。
  2. Map (映射)

    • 核心特征 :真正的键值对映射,Key 可以是任意类型(即使是对象或数组),并且保留了插入顺序
    • 适用场景 :需要建立关联关系(如 数字 -> 频次当前值 -> 需要的配对值)。
  3. Object (普通对象)

    • 算法建议在现代前端算法刷题中,尽量少用 Object 作为哈希表 。因为对象的 Key 只能是字符串或 Symbol,且存在原型链污染的风险,API 也不如 Map 丰富。无脑首选 Map

二、 核心题型与通用套路

阵营 A:找配对与状态记录 (Map 的主场)

这类题目的标志性特征是:在遍历当前元素时,你需要回头去查找之前是否出现过某个与之相关的元素

通用模板:边存边查 :不要上来就用两次循环(先存一遍,再查一遍),最佳实践是在一次 for 循环中,先检查 Map 里有没有自己需要的目标,如果没有,就把自己存进 Map 留给后面的元素用。

对应练习题:

  • LeetCode 1. 两数之和 :哈希表开山之作。遍历数组,计算 target - 当前数字,去 Map 中查这个差值是否存在。存在则返回索引,不存在则将 当前数字 -> 当前索引 存入 Map。
  • LeetCode 347. 前 K 个高频元素 :进阶状态记录。以 数字 -> 出现次数 建立映射,后续配合排序或桶排序提取结果。

阵营 B:去重、交集与源头试探 (Set 的主场)

这类题目的核心在于利用 SetO(1) 查找能力,快速过滤无效数据或建立参照系。

通用模板:全量初始化后探测 :直接使用 new Set(nums) 将原数据转化为纯净的参照字典,随后对字典进行遍历试探。

对应练习题:

  • LeetCode 349. 两个数组的交集 :将数组 A 转为 Set,遍历数组 B,利用 Set.has() 过滤出共有的元素,最后再去重输出。
  • LeetCode 128. 最长连续序列 :高阶应用。把数组全塞进 Set,然后遍历 Set。破局点 :利用 !set.has(num - 1) 来判断当前元素是不是一段序列的"龙头",只有龙头才配进入 while 循环往后数,从而强行将时间复杂度锁定在 O(n)

相关推荐
Shan12056 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo19986 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Asize6 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
hairenwangmiao7 小时前
B4041 [GESP202409 四级] 区间排序
算法·排序
人道领域7 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode
漂流瓶jz7 小时前
UVA-1606 两亲性分子 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·向量·aoapc·算法竞赛入门经典·atan2·浮点
Navigator_Z7 小时前
LeetCode //C - 1095. Find in Mountain Array
c语言·算法·leetcode
不会就选b8 小时前
算法日常・每日刷题--<二分查找>1
算法
「維他檸檬茶」8 小时前
大模型算法学习2026.6.13
学习·算法
叫我:松哥8 小时前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask