-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBoundedQueue.py
93 lines (75 loc) · 2.37 KB
/
BoundedQueue.py
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
86
87
88
89
90
91
92
93
from Array import Array
class Queue:
def __init__(self):
self._qhead = None
self._qtail = None
self._count = 0
def isEmpty(self):
return self._qhead is None
def __len__(self):
return self._count
def enqueue(self, item):
node = _QueueNode(item)
if self.isEmpty():
self._qhead = node
else:
self._qtail.next = node
self._qtail = node
self._count += 1
def dequeue(self):
assert not self.isEmpty(), "Can not be empty"
node = self._qhead
if self._qhead is self._qtail:
self._qtail = None
self._qhead = self._qhead.next
self._count -= 1
return node.item
def traverse(self):
assert not self.isEmpty()," cannot traverse through empty list"
node = self._qhead
while node:
print(node.item)
node = node.next
class _QueueNode(object):
def __init__(self, item):
self.item = item
self.next = None
class BoundedPri:
def __init__(self,numLevel):
self._qSize = 0
self._qLevels = Array(numLevel)
for i in range(numLevel):
self._qLevels[i] = Queue()
def isEmpty(self):
return self._qSize == 0
def __len__(self):
return self._qSize
def enqueue(self, item, priority):
assert priority >= 0 and priority < len(self._qLevels), "Invalid priority"
q = self._qLevels[priority]
q.enqueue(item)
self._qSize += 1
def dequeue(self):
assert not self.isEmpty(), "Empty queue"
for i in range(len(self._qLevels)):
q = self._qLevels[i]
if not q.isEmpty():
self._qSize -= 1
return q.dequeue()
def peek(self):
assert not self.isEmpty(), "Empty queue"
for i in range(len(self._qLevels)):
q = self._qLevels[i]
if not q.isEmpty():
return q.peek()
def traverse(self):
for i in range(len(self._qLevels)):
q = self._qLevels[i]
q.traverse()
obj = BoundedPri(3)
obj.enqueue("A", 1)
obj.enqueue("B", 0)
obj.enqueue("C", 2)
obj.enqueue("D", 0)
obj.traverse()
print("Dequeue: ", obj.dequeue())