Leetcode 1767 Solution
This article provides solution to leetcode question 1767 (design-front-middle-back-queue).
Access this page by simply typing in "lcs 1767" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/design-front-middle-back-queue
Solution
class FrontMiddleBackQueue:
def __init__(self):
self.q1 = deque()
self.q2 = deque()
def balance(self):
while len(self.q1) > len(self.q2):
self.q2.appendleft(self.q1.pop())
while len(self.q1) + 1 < len(self.q2):
self.q1.append(self.q2.popleft())
def pushFront(self, val: int) -> None:
self.q1.appendleft(val)
self.balance()
def pushMiddle(self, val: int) -> None:
self.q1.append(val)
self.balance()
def pushBack(self, val: int) -> None:
self.q2.append(val)
self.balance()
def popFront(self) -> int:
ans = None
if len(self.q1):
ans = self.q1.popleft()
elif len(self.q2):
ans = self.q2.popleft()
else:
ans = -1
self.balance()
return ans
def popMiddle(self) -> int:
ans = None
if len(self.q2) == 0:
ans = -1
elif len(self.q1) == len(self.q2):
ans = self.q1.pop()
else:
ans = self.q2.popleft()
self.balance()
return ans
def popBack(self) -> int:
ans = None
if len(self.q2):
ans = self.q2.pop()
else:
ans = -1
self.balance()
return ans
# Your FrontMiddleBackQueue object will be instantiated and called as such:
# obj = FrontMiddleBackQueue()
# obj.pushFront(val)
# obj.pushMiddle(val)
# obj.pushBack(val)
# param_4 = obj.popFront()
# param_5 = obj.popMiddle()
# param_6 = obj.popBack()