JS数据结构与算法-集合

简介: 定义集合是由一组无序且唯一(即不能重复)的项组成。可以把集合想象成一个既没有重复元素,也没有顺序概念的数组。创建一个集合我们使用对象而不是数组来表示集合,因为js的对象不允许一个键指向两个不同的属性,也保证了集合里的元素都是唯一的。
  1. 定义

集合是由一组无序且唯一(即不能重复)的项组成。
可以把集合想象成一个既没有重复元素,也没有顺序概念的数组。

  1. 创建一个集合
    我们使用对象而不是数组来表示集合,因为js的对象不允许一个键指向两个不同的属性,也保证了集合里的元素都是唯一的。
  • 定义set类
function Set() {
  var items = {};
}
  • 实现has方法,如果值在集合中,返回true,否则返回false
this.has = function(value) {
    return items.hasOwnProperty(value);
  };
  • 实现add方法,向集合添加一个新的项
  this.add = function(value) {
    //检查给定的value是否存在集合中,如果不存在,添加并返回true,反之返回false
    if(!this.has(value)) {
      items[value] = value;
      return true;
    }
    return false;
  };
  • 实现remove方法,从集合移除一个值。
this.remove = function(value) {
    //给定的value是否存在于集合中,如果存在,就从这个集合中删除value,返回true,表示值被移除;否则返回false
    if(this.has(value)) {
      delete items[value];
      return true;
    }
    return false;
  };
  • 实现clear方法,移除集合中的所有项
this.clear = function() {
    items = {};
};
  • 实现size方法,返回集合所包含元素的数量
this.size = function() {
    //使用Object.keys()方法
    return Object.keys(items).length;
 };
  • 实现values方法,返回一个包含集合中所有值的数组
this.values = function() {
    //使用Object.keys()方法提取items对象的所有属性
    return Object.keys(items);
};

全部代码:

function Set() {
  var items = {};

  //has方法如果值在集合中,返回true,否则返回false
  this.has = function(value) {
    return items.hasOwnProperty(value);
  };

  //add方法向集合添加一个新的项
  this.add = function(value) {
    //检查给定的value是否存在集合中,如果不存在,添加并返回true,反之返回false
    if(!this.has(value)) {
      items[value] = value;
      return true;
    }
    return false;
  };

  //remove方法,从集合中移除一个值
  this.remove = function(value) {
    //给定的value是否存在于集合中,如果存在,就从这个集合中删除value,返回true,表示值被移除;否则返回false
    if(this.has(value)) {
      delete items[value];
      return true;
    }
    return false;
  };

  //clear方法,移除集合中的所有项
  this.clear = function() {
    items = {};
  };

  //size方法返回集合中所包含元素的数量
  this.size = function() {
    //使用Object.keys()方法
    return Object.keys(items).length;
  };

  //values方法,返回一个包含集合中所有值的数组
  this.values = function() {
    //使用Object.keys()方法提取items对象的所有属性
    return Object.keys(items);
  };
}

var set = new Set();

 set.add(1);
 console.log(set.values()); // ["1"]
 console.log(set.has(1)); // true
 console.log(set.size()); // 1

参考学习

学习javascript数据结构与算法
数据结构与算法javascript描述

目录
相关文章
|
4月前
|
Java
【Java集合类面试二十六】、介绍一下ArrayList的数据结构?
ArrayList是基于可动态扩展的数组实现的,支持快速随机访问,但在插入和删除操作时可能需要数组复制而性能较差。
|
3月前
|
算法 JavaScript 前端开发
第一个算法项目 | JS实现并查集迷宫算法Demo学习
本文是关于使用JavaScript实现并查集迷宫算法的中国象棋demo的学习记录,包括项目运行方法、知识点梳理、代码赏析以及相关CSS样式表文件的介绍。
第一个算法项目 | JS实现并查集迷宫算法Demo学习
|
2月前
|
算法 安全 Java
【用Java学习数据结构系列】探索Java集合框架的无尽秘密pro
【用Java学习数据结构系列】探索Java集合框架的无尽秘密pro
19 1
|
3月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 集合(Collection)
JavaScript HTML DOM 集合(Collection)
36 4
|
3月前
|
存储 索引 Python
Python常用数据结构——集合
Python常用数据结构——集合
54 3
|
3月前
|
存储 Java 程序员
【数据结构】初识集合&深入剖析顺序表(Arraylist)
Java集合框架主要由接口、实现类及迭代器组成,包括Collection和Map两大类。Collection涵盖List(有序、可重复)、Set(无序、不可重复),Map则由键值对构成。集合通过接口定义基本操作,具体实现由各类如ArrayList、HashSet等提供。迭代器允许遍历集合而不暴露其实现细节。List系列集合元素有序且可重复,Set系列元素无序且不可重复。集合遍历可通过迭代器、增强for循环、普通for循环及Lambda表达式实现,各有适用场景。其中ArrayList实现了动态数组功能,可根据需求自动调整大小。
40 11
|
4月前
|
JavaScript 算法 前端开发
JS算法必备之String常用操作方法
这篇文章详细介绍了JavaScript中字符串的基本操作,包括创建字符串、访问特定字符、字符串的拼接、位置查找、大小写转换、模式匹配、以及字符串的迭代和格式化等方法。
JS算法必备之String常用操作方法
|
4月前
|
JavaScript 算法 前端开发
JS算法必备之Array常用操作方法
这篇文章详细介绍了JavaScript中数组的创建、检测、转换、排序、操作方法以及迭代方法等,提供了数组操作的全面指南。
JS算法必备之Array常用操作方法
|
4月前
|
算法 JavaScript 前端开发
国标非对称加密:RSA算法、非对称特征、js还原、jsencrypt和rsa模块解析
国标非对称加密:RSA算法、非对称特征、js还原、jsencrypt和rsa模块解析
300 1
|
4月前
|
存储 安全
集合的特点和数据结构总结
集合的特点和数据结构总结
33 1