2018-10-10 05:31:47 +08:00
|
|
|
"""
|
|
|
|
Queue based upon array
|
|
|
|
用数组实现的队列
|
|
|
|
|
|
|
|
Author: Wenru
|
|
|
|
"""
|
|
|
|
|
|
|
|
from typing import Optional
|
|
|
|
|
|
|
|
class ArrayQueue:
|
|
|
|
|
|
|
|
def __init__(self, capacity: int):
|
|
|
|
self._items = []
|
|
|
|
self._capacity = capacity
|
|
|
|
self._head = 0
|
|
|
|
self._tail = 0
|
|
|
|
|
|
|
|
def enqueue(self, item: str) -> bool:
|
2018-10-15 11:05:22 +08:00
|
|
|
if self._tail == self._capacity:
|
|
|
|
if self._head == 0:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
for i in range(0, self._tail - self._head):
|
2018-10-21 12:18:56 +08:00
|
|
|
self._items[i] = self._items[i + self._head]
|
2018-10-15 11:05:22 +08:00
|
|
|
self._tail = self._tail - self._head
|
|
|
|
self._head = 0
|
2018-10-10 05:31:47 +08:00
|
|
|
|
2018-10-15 11:05:22 +08:00
|
|
|
self._items.insert(self._tail, item)
|
2018-10-10 05:31:47 +08:00
|
|
|
self._tail += 1
|
|
|
|
return True
|
|
|
|
|
|
|
|
def dequeue(self) -> Optional[str]:
|
|
|
|
if self._head != self._tail:
|
|
|
|
item = self._items[self._head]
|
|
|
|
self._head += 1
|
|
|
|
return item
|
2019-03-04 14:15:54 +08:00
|
|
|
else:
|
|
|
|
return None
|
2018-10-10 05:31:47 +08:00
|
|
|
|
|
|
|
def __repr__(self) -> str:
|
|
|
|
return " ".join(item for item in self._items[self._head : self._tail])
|
|
|
|
|