-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmaxBinaryHeap.js
More file actions
70 lines (64 loc) · 1.82 KB
/
maxBinaryHeap.js
File metadata and controls
70 lines (64 loc) · 1.82 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
class MaxBinaryHeap {
constructor() {
this.values = []
}
insertElm(elm) {
this.values.push(elm)
this.bubbleUp()
}
bubbleUp() {
let idx = this.values.length - 1
const element = this.values[idx]
while(idx > 0) {
let parentIdx = Math.floor((idx - 1) / 2)
let parent = this.values[parentIdx]
if(parent >= element) break;
this.values[parentIdx] = element
this.values[idx] = parent
idx = parentIdx
}
}
extractMax() {
const max = this.values[0]
const end = this.values.pop()
this.values[0] = end;
this.sinkDown()
return max;
}
sinkDown(){
let idx = 0
let length = this.values.length
const element = this.values[idx]
while(true){
let leftchildIndex = (2 * idx) + 1
let rightchildIndex = (2 * idx) + 2
let leftChild;
let rightChild;
let swap = null;
if(leftChild < length) {
leftChild = this.values[leftchildIndex]
if(leftChild > element) {
swap = leftchildIndex
}
}
if (rightchildIndex < length) {
rightChild = this.values[rightchildIndex]
if((swap === null && rightChild > element) || (swap !== null && rightChild > leftChild)) {
swap = rightchildIndex
}
}
if( swap === null ) break;
this.values[idx] = this.values[swap]
this.values[swap] = element
idx = swap
}
}
}
const maxBinaryHeap = new MaxBinaryHeap()
maxBinaryHeap.insertElm(20)
maxBinaryHeap.insertElm(10)
maxBinaryHeap.insertElm(30)
maxBinaryHeap.insertElm(11)
maxBinaryHeap.insertElm(19)
console.log(maxBinaryHeap.extractMax())
console.log(maxBinaryHeap)