-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathqueue.js
More file actions
57 lines (45 loc) · 1.03 KB
/
queue.js
File metadata and controls
57 lines (45 loc) · 1.03 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
class Node {
value;
top;
bottom;
constructor(value, top = null, bottom = null) {
this.value = value;
this.top = top;
this.bottom = bottom;
}
}
class Queue {
bottom = null;
add(value) {
const newNode = new Node(value);
if(this.bottom) {
newNode.top = this.bottom;
this.bottom.bottom = newNode;
this.bottom = newNode;
return;
}
this.bottom = newNode;
}
print() {
let pointer = this.bottom;
while(pointer) {
console.log(pointer.value);
pointer = pointer.top;
}
}
dequeue() {
if (this.bottom) {
const oldBottom = this.bottom;
this.bottom = this.bottom.top;
if (this.bottom) {
this.bottom.bottom = null;
}
oldBottom.top = null;
}
}
}
const queue = new Queue();
queue.add("Andi");
queue.add("Edy");
queue.dequeue();
queue.print();