-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathleetcode-232-implementQueueUsingStacks.js
85 lines (75 loc) · 1.51 KB
/
leetcode-232-implementQueueUsingStacks.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
var MyQueue = function () {
this.input = [];
this.output = [];
};
/**
* @param {number} x
* @return {void}
*/
MyQueue.prototype.push = function (x) {
this.input.push(x);
};
/**
* @return {number}
*/
MyQueue.prototype.pop = function () {
if (this.output.length === 0) {
while (this.input.length > 0) {
this.output.push(this.input.pop());
}
}
return this.output.pop();
};
/**
* @return {number}
*/
MyQueue.prototype.peek = function () {
if (this.output.length === 0) {
while (this.input.length > 0) {
this.output.push(this.input.pop());
}
}
return this.output[this.output.length - 1];
};
/**
* @return {boolean}
*/
MyQueue.prototype.empty = function () {
return this.input.length === 0 && this.output.length === 0;
};
// var MyQueue = function () {
// this.queue = [];
// };
// /**
// * @param {number} x
// * @return {void}
// */
// MyQueue.prototype.push = function (x) {
// this.queue.push(x);
// };
// /**
// * @return {number}
// */
// MyQueue.prototype.pop = function () {
// return this.queue.shift();
// };
// /**
// * @return {number}
// */
// MyQueue.prototype.peek = function () {
// return this.queue[0];
// };
// /**
// * @return {boolean}
// */
// MyQueue.prototype.empty = function () {
// return this.queue.length === 0;
// };
// /**
// * Your MyQueue object will be instantiated and called as such:
// * var obj = new MyQueue()
// * obj.push(x)
// * var param_2 = obj.pop()
// * var param_3 = obj.peek()
// * var param_4 = obj.empty()
// */