集合Set是数学上的概念用在编程上,主要特点是组内的所有元素均不重复。
繁昌ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为成都创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:13518219792(备注:SSL证书合作)期待与您的合作!
Set的创建与Array等相同,使用关键词new
- let exampleSet = new Set();
Set只有一项属性即size.
- > exampleSet = new Set([1, 5, 8])
- Set(3) { 1, 5, 8 }
- > exampleSet.size
- 3
Set内建的操作方法包括:1)插入insertion 2) 删除 deletion 3) contain包含三项
- // insertion
- > sampleSet.add(17)
- Set(1) { 17 }
- > sampleSet.add(19)
- Set(2) { 17, 19 }
- > // delete
- > sampleSet.add(101)
- Set(3) { 17, 19, 101 }
- > sampleSet.delete(101)
- true
- > sampleSet
- Set(2) { 17, 19 }
- > // contains
- undefined
- > sampleSet.has(19)
- true
- > sampleSet.has(101)
- false
SET除去add, delete, has等基础的内建操作之外,我们较为常用的是 intersection(交集A*B),isSuperSet超集,Union并集等。
首先,交集的思路就是将setA与setB中的元素,setA*setB 并用contains做出判断。
- function intersectSets(setA, setB) {
- let intersection = new Set();
- for (let ele of setB) {
- if (setA.has(ele)) {
- intersection.add(ele);
- }
- }
- return intersection;
- }
- let setA = new Set([9, 12, 13, 24]);
- let setB = new Set([2, 13, 17, 24]);
- console.log(intersectSets(setA, setB)); /// Set {2, 3}/
其次是并集setA + setB 只需要逐个添加进来即可。
- function unionSet(setA, setB) {
- let union = new Set(setA);
- for (let elem of setB) {
- union.add(elem);
- }
- return union;
- }
- let setA = new Set([17, 23, 39, 47]),
- setB = new Set([29, 38]),
- setC = new Set([59]);
- console.log(unionSet(setA,setB));
- console.log(unionSet(setA,setC));
接着是差集,setA-setB将setB中的元素全部都删除。
- function differenceSet(setA, setB) {
- let difference = new Set(setA);
- for (let ele of setB) {
- difference.delete(ele);
- }
- return difference;
- }
- let setA = new Set([35, 98, 56, 47]),
- setB = new Set([25, 47]);
- console.log(differenceSet(setA, setB));
最后是超集和子集,因为互为逆运算,只需要写一个函数即可,具体实现,我们构思其否定形式,只要setB中有一个元素而不在其内,则判定为非超集。
- function isSuperset(setA, subset) {
- for (let elem of subset) {
- if (!setA.has(elem)) {
- return false;
- }
- }
- return true;
- }
- let setA = new Set([23, 35, 47, 59]),
- setB = new Set([23, 35]),
- setC = new Set([67]);
- console.log(isSuperset(setA, setB));
- console.log(isSuperset(setA, setC));
以上从Set内建操作 add, has, delete之外的 insection, union, difference, isSuperSet 四种操作。
数列查重往往需要先排序再逐个检查,但是用Set结构就简单多了,只需要比较其数据长度即可。
- function checkDuplicates(arr) {
- let mySet = new Set(arr);
- return mySet.size < arr.length;
- }
- checkDuplicates([11,27,38,49,52]); // false
- checkDuplicates([11,11,28,38,49,56]); // true
以上就是Set集合操作的所有方法。
网站栏目:JavaScript之集合Set操作的3类10种方法
地址分享:http://www.shufengxianlan.com/qtweb/news27/149777.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联