Sha256: f7093e776a1db1d0c4a80175d9f4d02bb50c93c8a5c0bc25a5c88946ad286a2f

Contents?: true

Size: 804 Bytes

Versions: 185

Compression:

Stored size: 804 Bytes

Contents

class BinarySearchTree {
  constructor(data) {
    this.data = data;
    this.left = undefined;
    this.right = undefined;
  }

  insert(value) {
    if (value <= this.data) {
      this.insertLeft(value);
    } else {
      this.insertRight(value);
    }

    return this;
  }

  insertLeft(value) {
    if (!this.left) {
      this.left = new BinarySearchTree(value);
    } else {
      this.left.insert(value);
    }

    return this;
  }

  insertRight(value) {
    if (!this.right) {
      this.right = new BinarySearchTree(value);
    } else {
      this.right.insert(value);
    }

    return this;
  }

  each(fn) {
    if (this.left) {
      this.left.each(fn);
    }
    fn.call(this, this.data);
    if (this.right) {
      this.right.each(fn);
    }
  }
}

export default BinarySearchTree;

Version data entries

185 entries across 185 versions & 1 rubygems

Version Path
trackler-2.2.1.119 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.118 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.117 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.116 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.115 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.114 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.113 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.111 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.110 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.109 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.108 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.107 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.106 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.105 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.104 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.103 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.102 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.101 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.100 tracks/ecmascript/exercises/binary-search-tree/example.js
trackler-2.2.1.99 tracks/ecmascript/exercises/binary-search-tree/example.js