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描述

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 翻译自“Collection View Programming Guide for iOS” 0 关于iOS集合视...
    lakerszhy阅读 3,955评论 1 22
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,281评论 0 4
  • 凡事不能往好的方面想,因为希望越大伴随的失望也越大,正所谓福祸相依。其实只要一颗平常心却对待就好,可是很难控制的住...
    柯和丹阅读 322评论 0 0
  • 我是一个来自于偏僻村落里的菇凉,那里房子后面是青山,房子前面是绿水。只是不管是那山,还是那水,我从来不敢靠近,也无...
    0静子0阅读 644评论 2 0
  • ***1*** 接连不断的复习,作业,预习,语数英三科并进。 上周,三科的测验密集而来,Lincoln被这个阵势搞...
    林一林阅读 586评论 0 1