-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstack.js
More file actions
77 lines (57 loc) · 1.26 KB
/
stack.js
File metadata and controls
77 lines (57 loc) · 1.26 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
74
75
76
77
class Node {
value;
top;
bottom;
constructor(value, top = null, bottom = null) {
this.value = value;
this.top = top;
this.bottom = bottom;
}
}
class Stack {
top = null;
add(value) {
const newNode = new Node(value);
if(this.top) {
newNode.bottom = this.top;
this.top.top = newNode;
this.top = newNode;
return;
}
this.top = newNode;
};
remove() {
if (this.top) {
const oldTop = this.top;
this.top = this.top.bottom;
if (this.top) {
this.top.top = null;
}
oldTop.bottom = null;
}
}
find(value) {
let pointer = this.top;
while(pointer) {
if(pointer.value == value) {
return "Found " + value;
}
pointer = pointer.bottom;
}
return "Not found";
}
print() {
let pointer = this.top;
while(pointer) {
console.log(pointer.value);
pointer = pointer.bottom;
}
}
}
const stack = new Stack();
stack.add(5);
stack.add(1);
stack.add(3);
stack.remove();
console.log(stack.find(6));
stack.print();