-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmax-binary-heap.js
More file actions
73 lines (71 loc) · 1.84 KB
/
Copy pathmax-binary-heap.js
File metadata and controls
73 lines (71 loc) · 1.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
export default class MaxBinaryHeap {
constructor() {
this.values = []
}
insert(val) {
this.values.push(val)
this.bubbleUp()
}
bubbleUp() {
let idx = this.values.length - 1
let element = this.values[idx]
while (idx > 0) {
let parentIdx = Math.floor((idx - 1) / 2)
let parent = this.values[parentIdx]
if (element <= parent) break
this.values[parentIdx] = element
this.values[idx] = parent
idx = parentIdx
}
}
/**
* Extract max (root node) includes three steps
*
* - Remove the root
* - Replace with the most recently added
* - Adjust (sink down)
*/
extractMax() {
const max = this.values[0]
const end = this.values.pop()
if (this.values.length > 0) {
this.values[0] = end
this.sinkDown()
}
return max
}
/**
* The procedure for deleting the root from the heap (effectively extracting the maximum element in a max-heap
* or the minimum element in a min-heap) and restoring the properties is called down-heap
*/
sinkDown() {
let idx = 0;
const length = this.values.length;
const element = this.values[0];
while (true) {
let leftChildIdx = 2 * idx + 1;
let rightChildIdx = 2 * idx + 2;
let leftChild, rightChild;
let swap = null;
if (leftChildIdx < length) {
leftChild = this.values[leftChildIdx];
if (leftChild > element) {
swap = leftChildIdx;
}
}
if (rightChildIdx < length) {
rightChild = this.values[rightChildIdx];
if (
(swap === null && rightChild > element) ||
(swap !== null && rightChild > leftChild)
) {
swap = rightChildIdx;
}
}
if (swap === null) break;
this.values[idx] = this.values[swap];
this.values[swap] = element;
idx = swap;
}
}
}