-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmycirclelist.py
118 lines (103 loc) · 2.89 KB
/
mycirclelist.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
class Node(object):
def __init__(self, value=None, prev=None, next=None):
self.value = value
self.prev = prev
self.next = next
class CircleList(object):
def __init__(self):
node = Node()
self.root = node
self.root.prev = node
self.root.next = node
self.length = 0
def headnode(self):
return self.root.next
def tailnode(self):
return self.root.prev
def iter_node(self):
flagenode = self.root.next
while flagenode.next is not self.root:
yield flagenode
flagenode = flagenode.next
yield flagenode
def __iter__(self):
for node in self.iter_node():
yield node.value
def append(self, value):
node = Node(value)
tailnode = self.tailnode()
tailnode.next = node
node.prev = tailnode
self.root.prev = node
node.next = self.root
self.length += 1
def find(self, index):
flagindex = 0
if index >=0 and index <= self.length - 1:
for node in self.iter_node():
if flagindex == index:
return node
flagindex += 1
else:
raise Exception('out of range')
def remove(self, index):
node = self.find(index)
if node is not self.root:
node.prev.next = node.next
node.next.prev = node.prev
self.length -= 1
del node
else:
raise Exception('list is empty')
def update(self, index, value):
node = self.find(index)
if node is not self.root:
node.value = value
else:
raise Exception('list is empty')
def reverse(self):
tailnode = self.tailnode()
while tailnode.prev is not self.root:
yield tailnode.value
tailnode = tailnode.prev
yield tailnode.value
# a = CircleList()
# a.append(1)
# a.append(2)
# a.append(3)
# # print(a.find(2).value)
# # a.remove(0)
# # a.update(1, 9)
# listd = [i for i in a]
# # a.reverse()
# relist = [i for i in a.reverse()]
#
# print(listd)
# print(relist)
class Deque(CircleList):
# 实现双端队列就等于是同时实现了队列和栈了
# 当然还有跟更简单的方法,直接调用list的push和pop
# 可以快速实现队列和栈
def __len__(self):
return self.length
def pop(self):
if len(self) == 0:
return None
headnode = self.headnode()
value = headnode.value
self.remove(0)
return value
def popleft(self):
if len(self) == 0:
return None
tailnode = self.tailnode()
value = tailnode.value
self.remove(self.length - 1)
return value
# dequ = Deque()
# dequ.append(1)
# dequ.append(2)
# dequ.append(3)
# print(dequ.popleft())
# print(dequ.popleft())
# print(dequ.popleft())