-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1670_design-front-middle-back-queue.js
72 lines (64 loc) · 1.55 KB
/
1670_design-front-middle-back-queue.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
/**
* Title: Design Front Middle Back Queue
* Description: Design a queue that supports push and pop operations in the front, middle, and back.
* Author: Hasibul Islam
* Date: 28/04/2023
*/
var FrontMiddleBackQueue = function () {
this.queue = [];
};
/**
* @param {number} val
* @return {void}
*/
FrontMiddleBackQueue.prototype.pushFront = function (val) {
this.queue.unshift(val);
};
/**
* @param {number} val
* @return {void}
*/
FrontMiddleBackQueue.prototype.pushMiddle = function (val) {
let middle = Math.floor(this.queue.length / 2);
this.queue.splice(middle, 0, val);
};
/**
* @param {number} val
* @return {void}
*/
FrontMiddleBackQueue.prototype.pushBack = function (val) {
this.queue.push(val);
};
/**
* @return {number}
*/
FrontMiddleBackQueue.prototype.popFront = function () {
if (!this.queue.length) return -1;
return this.queue.shift();
};
/**
* @return {number}
*/
FrontMiddleBackQueue.prototype.popMiddle = function () {
if (!this.queue.length) return -1;
let middle = Math.floor(this.queue.length / 2);
if (this.queue.length % 2 == 0) middle--;
return this.queue.splice(middle, 1);
};
/**
* @return {number}
*/
FrontMiddleBackQueue.prototype.popBack = function () {
if (!this.queue.length) return -1;
return this.queue.pop();
};
/**
* Your FrontMiddleBackQueue object will be instantiated and called as such:
* var obj = new FrontMiddleBackQueue()
* obj.pushFront(val)
* obj.pushMiddle(val)
* obj.pushBack(val)
* var param_4 = obj.popFront()
* var param_5 = obj.popMiddle()
* var param_6 = obj.popBack()
*/