-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLinkedListNew.py
169 lines (146 loc) · 4.32 KB
/
LinkedListNew.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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
class Node:
def __init__(self, value):
self.value = value
self.next = None
class LinkedList:
# def __init__(self, value):
# new_node = Node(value)
# self.head = new_node
# self.tail = new_node
# self.length = 1
def __init__(self):
self.head = None
self.tail = None
self.length = 0
def __str__(self):
temp_node = self.head
result = ''
while temp_node is not None:
result += str(temp_node.value)
if temp_node.next is not None:
result += ' -> '
temp_node = temp_node.next
return result
def append(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
self.tail.next = new_node
self.tail = new_node
self.length += 1
def prepend(self, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
else:
new_node.next = self.head
self.head = new_node
self.length += 1
def insert(self, index, value):
new_node = Node(value)
if self.head is None:
self.head = new_node
self.tail = new_node
elif index == 0:
new_node.next = self.head
self.head = new_node
else:
temp_node = self.head
for _ in range(index-1):
temp_node = temp_node.next
new_node.next = temp_node.next
temp_node.next = new_node
self.length += 1
def traverse(self):
current = self.head
while current is not None:
print(current.value)
current = current.next
def search(self, target):
current = self.head
while current is not None:
if current.value == target:
return True
current = current.next
return False
def search(self, target):
current = self.head
index = 0
while current is not None:
if current.value == target:
return index
current = current.next
index += 1
return -1
def get(self, index):
if index == -1:
return self.tail
elif index < -1 or index >= self.length:
return None
current = self.head
for _ in range(index):
current = current.next
return current
def set_value(self, index, value):
temp = self.get(index)
if temp:
temp.value = value
return True
return False
def pop_first(self):
if self.length == 0:
return None
popped_node = self.head
if self.length == 1:
self.head = None
self.tail = None
else:
self.head = self.head.next
popped_node.next = None
self.length -= 1
return popped_node
def pop(self):
if self.length == 0:
return None
popped_node = self.tail
if self.length == 1:
self.head = self.tail = None
else:
temp = self.head
while temp.next is not self.tail:
temp = temp.next
temp.next = None
self.tail = temp
self.length -= 1
return popped_node
def remove(self, index):
if index < -1 or index >= self.length:
return None
if index == 0:
return self.pop_first()
if index == -1 or index == self.length-1:
return self.pop()
prev_node = self.get(index-1)
popped_node = prev_node.next
prev_node.next = popped_node.next
popped_node.next = None
self.length -= 1
return popped_node
def remove(self, index):
prev_node = self.get(index-1)
popped_node = prev_node.next
prev_node.next = popped_node.next
popped_node.next = None
self.length -= 1
return popped_node
linked_list = LinkedList()
linked_list.append(10)
linked_list.append(20)
linked_list.append(30)
linked_list.append(40)
print(linked_list)
print(linked_list.remove(0))
print(linked_list)