Skip to content

Latest commit

 

History

History
165 lines (118 loc) · 4.08 KB

README.md

File metadata and controls

165 lines (118 loc) · 4.08 KB

Data Structures Again

Coverage Status npm version

Light weight javascript data structures library

  • Binary Search Tree
  • Stack
  • Queue
  • Heap
  • Graph
  • Disjoint-set
  • LRU Cache (New!)
  • HashSet

Installation and Usage

npm install data-structures-again

Binary Search Tree:

const { BST } = require("data-structures-again");

const bst = new BST();
bst.insert(2);
bst.insert(1);
const node = bst.search(1); // { data: 1, left: null, right: null }
bst.delete(1);

Stack:

const { Stack } = require("data-structures-again");

const stack = new Stack();
stack.push(1);
stack.push(2);
const data = stack.pop(); // 2
const top = stack.peek(); // 1

Queue:

const { Queue } = require("data-structures-again");

const queue = new Queue();
queue.enqueue(1);
queue.enqueue(2);
const data = queue.dequeue(); // 1
const top = queue.peek(); // 2

Heap:

const { Heap } = require("data-structures-again");

const minHeap = new Heap()
minHeap.push(5)
minHeap.push(2)
minHeap.peek()  // 2


const maxHeap = new Heap((a, b) => b - a)
maxHeap.push(4)
maxHeap.push(10)
maxHeap.peek() // 10

Graph

const { Graph } = require("data-structures-again");

const graph = new Graph()

/*
    a---b
    |  /    
    | /
    c
*/

graph.addVertex('a')
graph.addVertex('b')
graph.addVertex('c')

graph.addEdge('a', 'c') // add weight using graph.addEdge('a', 'c', 10)
graph.addEdge('c', 'b')
graph.addEdge('a', 'b')

const output = []
graph.dfs('a', vertex => output.push(vertex.name)) // ['a', 'c', 'b']

Disjoint Set(Union-find)

const { DisjointSet } = require("data-structures-again");

const ds = new DisjointSet()
ds.union('a', 'b')
ds.union('b', 'c')
ds.union('d', 'c')

ds.find('d') // 'a'
ds.isConnected('a', 'd') // true

LRUCache

const { LRUCache } = require("data-structures-again");

const lru = new LRUCache(2)

lru.put(1, 1)
lru.put(2, 2)
lru.get(1)    // 1
lru.put(3, 3)
lru.get(2)   // -1
lru.put(4, 4)
lru.get(1)   // -1
lru.get(3)   // 3
lru.get(4)   // 4

Hash-set

const { HashSet } = require("data-structures-again");

const set = new HashSet()
set.add(1)
set.add(2)

set.has(1) // true
set.has(2) // true
set.has(3)) // false

License

MIT.