set和map结构,减少O(n)复杂度

第一阶段:Set 基础

一、Set 创建方式(set的结构可以看成对象)
TypeScript 复制代码
const set = new Set();
初始化:
TypeScript 复制代码
const set = new Set([1, 2, 3, 3, 4]);

console.log(set);
// Set(4) {1,2,3,4}
二、常用方法
方法 说明
add(value) 添加
delete(value) 删除
has(value) 是否存在
clear() 清空
size 长度
三、遍历方式
TypeScript 复制代码
const s = new Set([1,2,3]);

for (const item of s) {
  console.log(item);
}
forEach:
TypeScript 复制代码
s.forEach(item => console.log(item));
六、Set 使用场景
方法1:转数组
TypeScript 复制代码
[...s].forEach((item,index)=>{
  console.log(index,item);
});
方法2:
TypeScript 复制代码
Array.from(s).forEach((item,index)=>{
  console.log(index,item);
});

第二阶段:Map 基础入门

一、Map 创建 (Map的结构可以看成二维数组,即 \[ key,value ])
TypeScript 复制代码
const map = new Map();
二、基本方法
方法 说明
set(key, value) 设置
get(key) 获取
has(key) 是否存在
delete(key) 删除
clear() 清空
size 长度
TypeScript 复制代码
const map = new Map();

map.set('name', 'Tom');
map.set('age', 20);

console.log(map.get('name')); // Tom
console.log(map.size); // 2
三、key 可为任意类型
TypeScript 复制代码
const objKey = { id: 1 };

const map = new Map();

map.set(objKey, '对象key');

console.log(map.get(objKey));
对比 Object:
TypeScript 复制代码
const obj = {};

obj[objKey] = 'test';

console.log(obj);
// key 被转成字符串
四、遍历 Map
for...of
TypeScript 复制代码
for (const [key, value] of map) {
  console.log(key, value);
}
keys()
TypeScript 复制代码
for (const key of map.keys()) {}
values()
TypeScript 复制代码
for (const value of map.values()) {}
五、Map 转数组
TypeScript 复制代码
const arr = [...map];
六、数组转 Map
TypeScript 复制代码
const map = new Map([
  ['name', 'Tom'],
  ['age', 20]
]);

第四阶段:Set 与 Map 深度理解
一、底层复杂度
Set:
  • add:O(1)
  • delete:O(1)
  • has:O(1)
Array:
  • includes:O(n)
二、引用类型注意点
TypeScript 复制代码
const s = new Set();

s.add({a:1});
s.add({a:1});

console.log(s.size); // 2
原因:

对象地址不同

三、NaN 特殊性
TypeScript 复制代码
const s = new Set();

s.add(NaN);
s.add(NaN);

console.log(s.size); // 1
第五阶段:高级实战
一、数组交集
TypeScript 复制代码
const a = [1,2,3];
const b = [2,3,4];

const intersection = a.filter(item => new Set(b).has(item));

console.log(intersection);
// [2,3]
二、数组并集
TypeScript 复制代码
const union = [...new Set([...a, ...b])];
三、数组差集
TypeScript 复制代码
const diff = a.filter(item => !new Set(b).has(item));
四、统计词频(Map)
TypeScript 复制代码
const words = ['a', 'b', 'a', 'c', 'b'];

const wordMap = new Map();

for (const word of words) {
  wordMap.set(word, (wordMap.get(word) || 0) + 1);
}

console.log(wordMap);
五、缓存机制(重要)
TypeScript 复制代码
const cache = new Map();

function getData(id) {
  if (cache.has(id)) {
    return cache.get(id);
  }

  const data = fetchData(id);

  cache.set(id, data);

  return data;
}
第六阶段:常见坑点
1. JSON 无法直接序列化 Map/Set
TypeScript 复制代码
JSON.stringify(new Set([1,2]));
// {}

正确方式:

TypeScript 复制代码
JSON.stringify([...set]);
2. 对象引用问题
TypeScript 复制代码
set.add({});
set.add({});

结果不同对象

相关推荐
NiceCloud喜云20 分钟前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby1 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
GISer_Jing1 小时前
Three.js着色器编译机制深度解析
javascript·webgl·着色器
丷丩1 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
油炸自行车1 小时前
Claude Code 错误:API Error: 400 Failed to deserialize the JSON body into the
开发语言·javascript·json·trae·claude code·api error 400
Front思2 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫4 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。5 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星5 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒5 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端