面试官:说说你对集合的理解?常见的操作有哪些?

开发 前端
使用set集合的场景一般是借助其确定性,其本身只包含不同的元素,所以,可以利用Set的一些原生方法轻松的完成数组去重,查找数组公共元素及不同元素等操作。

[[425687]]

本文转载自微信公众号「JS每日一题」,作者灰灰。转载本文请联系JS每日一题公众号。

 

一、是什么

集合(Set),指具有某种特定性质的事物的总体,里面的每一项内容称作元素

在数学中,我们经常会遇到集合的概念:

  • 有限集合:例如一个班级所有的同学构成的集合
  • 无限集合:例如全体自然数集合

在计算机中集合道理也基本一致,具有三大特性:

  • 确定性:于一个给定的集合,集合中的元素是确定的。即一个元素,或者属于该集合,或者不属于该集合,两者必居其一
  • 无序性:在一个集合中,不考虑元素之间的顺序,只要元素完全相同,就认为是同一个集合
  • 互异性:集合中任意两个元素都是不同的

二、操作

在ES6中,集合本身是一个构建函数Set,用来生成 Set 数据结构,如下:

  1. const s = new Set(); 

关于集合常见的方法有:

  • add():增
  • delete():删
  • has():改
  • clear():查

add()

添加某个值,返回 Set 结构本身

当添加实例中已经存在的元素,set不会进行处理添加

  1. s.add(1).add(2).add(2); // 2只被添加了一次 

体现了集合的互异性特性

delete()

删除某个值,返回一个布尔值,表示删除是否成功

  1. s.delete(1) 

has()

返回一个布尔值,判断该值是否为Set的成员

  1. s.has(2) 

clear()

清除所有成员,没有返回值

  1. s.clear() 

关于多个集合常见的操作有:

  • 并集
  • 交集
  • 差集

并集

两个集合的共同元素,如下图所示:

代码实现方式如下:

  1. let a = new Set([1, 2, 3]); 
  2. let b = new Set([4, 3, 2]); 
  3.  
  4. // 并集 
  5. let union = new Set([...a, ...b]); 
  6. // Set {1, 2, 3, 4} 

交集

两个集合A 和 B,即属于A又属于B的元素,如下图所示:

用代码标识则如下:

  1. let a = new Set([1, 2, 3]); 
  2. let b = new Set([4, 3, 2]); 
  3.  
  4. // 交集 
  5. let intersect = new Set([...a].filter(x => b.has(x))); 
  6. // set {2, 3} 

差集

两个集合A 和 B,属于A的元素但不属于B的元素称为A相对于B的差集,如下图所示:

代码标识则如下:

  1. let a = new Set([1, 2, 3]); 
  2. let b = new Set([4, 3, 2]); 
  3.  
  4. // (a 相对于 b 的)差集 
  5. let difference = new Set([...a].filter(x => !b.has(x))); 
  6. // Set {1} 

三、应用场景

一般情况下,使用数组的概率会比集合概率高很多

使用set集合的场景一般是借助其确定性,其本身只包含不同的元素

所以,可以利用Set的一些原生方法轻松的完成数组去重,查找数组公共元素及不同元素等操作

参考文献

https://zh.wikipedia.org/wiki/%E5%B9%B6%E9%9B%86

 

https://zh.wikipedia.org/wiki/%E8%A1%A5%E9%9B%86

 

责任编辑:武晓燕 来源: JS每日一题
相关推荐

2021-09-27 06:50:04

非线性数据

2021-08-20 08:33:19

操作系统OS

2021-08-09 07:47:40

Git面试版本

2021-11-25 10:18:42

RESTfulJava互联网

2021-09-09 07:21:26

TypeScript 高级类型

2020-12-01 08:47:36

Java异常开发

2020-06-12 15:50:56

options前端服务器

2021-09-30 07:57:13

排序算法面试

2021-05-27 05:37:10

HTTP请求头浏览器

2021-10-29 09:40:21

设计模式软件

2021-09-16 07:52:18

算法应用场景

2019-05-10 10:50:04

Spring AOPJDK动态代理CGLIB动态代理

2021-11-02 22:04:58

模式

2022-02-21 17:24:18

序列化对象存储

2021-08-16 08:33:26

git

2021-11-10 07:47:49

组合模式场景

2021-11-03 14:10:28

工厂模式场景

2020-12-04 06:27:04

序列化面试官Java

2021-11-05 07:47:56

代理模式对象

2021-11-09 08:51:13

模式命令面试
点赞
收藏

51CTO技术栈公众号