请你设计一个队列,支持在前,中,后三个位置的 push 和 pop 操作。
push
pop
请你完成 FrontMiddleBack 类:
FrontMiddleBack
FrontMiddleBack()
void pushFront(int val)
val
void pushMiddle(int val)
void pushBack(int val)
int popFront()
-1
int popMiddle()
int popBack()
请注意当有 两个 中间位置的时候,选择靠前面的位置进行操作。比方说:
6
[1, 2, 3, 4, 5]
[1, 2, 6, 3, 4, 5]
[1, 2, 3, 4, 5, 6]
3
[1, 2, 4, 5, 6]
示例 1:
输入: ["FrontMiddleBackQueue", "pushFront", "pushBack", "pushMiddle", "pushMiddle", "popFront", "popMiddle", "popMiddle", "popBack", "popFront"] [[], [1], [2], [3], [4], [], [], [], [], []] 输出: [null, null, null, null, null, 1, 3, 4, 2, -1] 解释: FrontMiddleBackQueue q = new FrontMiddleBackQueue(); q.pushFront(1); // [1] q.pushBack(2); // [1, 2] q.pushMiddle(3); // [1, 3, 2] q.pushMiddle(4); // [1, 4, 3, 2] q.popFront(); // 返回 1 -> [4, 3, 2] q.popMiddle(); // 返回 3 -> [4, 2] q.popMiddle(); // 返回 4 -> [2] q.popBack(); // 返回 2 -> [] q.popFront(); // 返回 -1 -> [] (队列为空)
提示:
1 <= val <= 109
1000
pushFront
pushMiddle
pushBack
popFront
popMiddle
popBack