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({});

结果不同对象

相关推荐
hunteritself1 小时前
GPT Image2 + Seedance 2.0:3 小时从剧本到 AI 互动影游,深度实测复盘
前端·数据库·人工智能·深度学习·transformer
独秀不如众秀1 小时前
前端页面引擎协议:由浅入深——从 30 行到 vform3 的演化之路
前端
学网安的肆伍1 小时前
【044-WEB攻防篇】PHP应用&SQL盲注&布尔回显&延时判断&报错处理&增删改查方式
前端·sql·php
八号当铺2 小时前
从 Prompt 到 AI 工程化:理解 Rules、Skills 与 Agent
前端·ai编程·cursor
倒带人生2 小时前
将 $confirm 对话框改为 a-modal 实现的通用技术方案
javascript·ant design
didadida2622 小时前
子路径部署 Vue/React 应用偶发白屏
前端·后端
invicinble2 小时前
前端框架使用vue-cli (第五层:构建打包层--总体层介绍)
前端·vue.js·前端框架
前端那点事2 小时前
Vuex刷新数据丢失?4种持久化方案全覆盖,从零到项目落地(实战完整版)
前端·vue.js
Cerrda2 小时前
性能提升 satisfying!一个 Vue3 指令干掉页面上 200 个无用 Tooltip 实例
前端·设计