-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathpriorityQueue.js
125 lines (106 loc) · 3.29 KB
/
priorityQueue.js
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
class Node {
constructor (val, priority) {
this.val = val;
this.priority = priority;
}
}
class PriorityQueue {
constructor () {
this.values = [];
}
enqueue (val, priority) {
const node = new Node(val, priority);
this.values.push(node);
this.bubbleUp();
}
dequeue () {
const min = this.values[0];
const end = this.values.pop();
if (this.values.length > 0) {
this.values[0] = end;
this.bubbleDown(0);
}
return min;
}
bubbleUp () {
let idx = this.values.length - 1;
while (idx > 0) {
const parentIdx = Math.floor((idx - 1) / 2);
if (this.values[idx].priority >= this.values[parentIdx].priority) {
break;
}
const tmp = this.values[parentIdx];
this.values[parentIdx] = this.values[idx];
this.values[idx] = tmp;
idx = parentIdx;
}
}
// Recursive
bubbleDown (index) {
const length = this.values.length;
let largest = index;
const left = 2 * index + 1;
const right = 2 * index + 2;
// if left child is greater than parent
if (left <= length && this.values[left]) {
if (this.values[left].priority < this.values[largest].priority) {
largest = left;
}
}
// if right child is greater than parent
if (right <= length && this.values[right]) {
if (this.values[right].priority < this.values[largest].priority) {
largest = right;
}
}
// swap
if (largest !== index) {
[this.values[largest], this.values[index]] = [this.values[index], this.values[largest]];
this.bubbleDown(largest);
}
}
// Iterative
bubbleDownIterative () {
let idx = 0;
const length = this.values.length;
const element = this.values[0];
while (true) {
const leftChildIdx = 2 * idx + 1;
const rightChildIdx = 2 * idx + 2;
let leftChild, rightChild;
let swap = null;
if (leftChildIdx < length) {
leftChild = this.values[leftChildIdx];
if (leftChild.priority > element.priority) {
swap = leftChildIdx;
}
}
if (rightChildIdx < length) {
rightChild = this.values[rightChildIdx];
if (
(swap === null && rightChild.priority > element.priority) ||
(swap !== null && rightChild.priority > leftChild.priority)
) {
swap = rightChildIdx;
}
}
if (swap === null) break;
this.values[idx] = this.values[swap];
this.values[swap] = element;
idx = swap;
}
}
}
const ER = new PriorityQueue();
ER.enqueue('common cold', 5);
ER.enqueue('gunshot wound', 1);
ER.enqueue('high fever', 4);
ER.enqueue('broken arm', 2);
ER.enqueue('glass in foot', 3);
console.log(ER.dequeue());
console.log(ER.dequeue());
console.log(ER.dequeue());
console.log(ER.dequeue());
console.log(ER.dequeue());
console.log(ER.dequeue());
console.log(ER.dequeue());