Sha256: 7195699fb52a887d6c9732cd83bc77d480602a77eadd2878fe3ecf961e6fd1f4

Contents?: true

Size: 1.18 KB

Versions: 36

Compression:

Stored size: 1.18 KB

Contents

export default class CustomSet {
  constructor(data = []) {
    this.data = {};
    data.forEach(el => this.put(el));
    this.comparator = typeof data[0] === 'number' ?
      (a, b) => a - b
      : (a, b) => b <= a
      ? 1 : -1;
  }

  delete(el) {
    delete this.data[el];
    return this;
  }

  eql(other) {
    return this.difference(other).size() === 0;
  }

  difference(other) {
    return new CustomSet(Object.keys(this.data).filter(el => other.data[el] === undefined));
  }

  disjoint(other) {
    return this.size === 0 || this.difference(other).size() === this.size();
  }

  intersection(other) {
    return this.difference(this.difference(other));
  }

  union(other) {
    return new CustomSet(this.toList().concat(this.difference(other).toList()));
  }

  subset(other) {
    return other.eql(this.intersection(other));
  }

  toList() {
    return Object.keys(this.data).map(el => +el);
  }

  member(el) {
    return this.data[el] !== undefined;
  }

  put(value) {
    this.data[value] = value;
    return this;
  }

  sort() {
    this.data.sort(this.comparator);
  }

  size() {
    return Object.keys(this.data).length;
  }

  empty() {
    this.data = {};
    return this;
  }
}

Version data entries

36 entries across 36 versions & 1 rubygems

Version Path
trackler-2.2.1.29 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.28 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.27 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.26 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.25 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.24 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.23 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.22 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.21 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.20 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.19 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.18 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.17 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.16 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.15 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.14 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.13 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.12 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.11 tracks/ecmascript/exercises/custom-set/example.js
trackler-2.2.1.10 tracks/ecmascript/exercises/custom-set/example.js