-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLinkedList.py
170 lines (136 loc) · 4.54 KB
/
LinkedList.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
'''
Author: Sai Uday Bhaskar Mudivarty
Program: Single Linked List
'''
class Node:
def __init__(self,data,next):
self.data = data
self.next = next
class LinkedList:
def __init__(self):
self.root = None
self.size = 0
def add(self,data):
newNode = Node(data,None)
if self.root == None:
self.root = newNode
else:
currentNode = self.root
while currentNode.next != None:
currentNode = currentNode.next
currentNode.next = newNode
self.size = self.size + 1
def delete(self,data):
isFound = False
currentNode = self.root
while not isFound and currentNode != None:
if currentNode.data == data:
if currentNode == self.root:
self.root = currentNode.next
else:
prev.next = currentNode.next
del currentNode
self.size = self.size -1
isFound = True
print ("Deleted "+str(data)+" from the linked list")
break
prev = currentNode
currentNode = currentNode.next
if not isFound:
raise ValueError("Value not found in LinkedList")
def printList(self):
currentNode = self.root
i = 1
while currentNode != None:
print(str(i)+ ". "+str(currentNode.data))
currentNode = currentNode.next
i+=1
def search(self,data):
currentNode = self.root
while currentNode !=None:
if currentNode.data == data:
print("Found "+str(data)+" in the linked list")
return currentNode
currentNode = currentNode.next
print(str(data)+" is not found in the linked list")
def addAsRoot(self,data):
newNode = Node(data,self.root)
self.root = newNode
self.size = self.size+1
def addAtNthPosition(self,data,n):
try:
if n ==1:
self.addAsRoot(data)
elif n > self.__len__()+1:
raise StandardError()
else:
currentNode = self.root
for i in range(1,n-1):
currentNode = currentNode.next
newNode = Node(data,currentNode.next)
currentNode.next = newNode
self.size = self.size +1
except StandardError:
print("The size of the linked list is less than the size of the desired position")
print("Unable to Add "+str(data)+ " at "+str(n)+" position.")
def deleteNodeAtNthPosition(self,n):
try:
currentNode = self.root
if n == 1:
self.root = currentNode.next
del currentNode
elif n > self.__len__()+1:
raise StandardError()
else:
for i in range(1,n-1):
currentNode = currentNode.next
currentNode.next = (currentNode.next).next
x = currentNode.next
del x
except StandardError:
print("Out Of Bound: Unable to delete the element at "+str(n)+" position")\
def reverseList(self):
currentNode = self.root
prevNode = None
nextNode = None
while currentNode != None:
nextNode = currentNode.next
currentNode.next = prevNode
prevNode = currentNode
currentNode = nextNode
self.root = prevNode
self.printList()
def reversePrintRecursive(self,node):
if node == None:
return
self.reversePrintRecursive(node.next)
print(node.data)
def reverseListRecursive(self,node):
if node.next is None:
self.root = node
return
self.reverseListRecursive(node.next)
latter = node.next
latter.next = node
node.next = None
def __len__(self):
return self.size
if __name__ == '__main__':
ll = LinkedList()
ll.add(10)
ll.add(12)
ll.add(14)
ll.add(100)
ll.printList()
print("")
ll.addAtNthPosition(101,5)
ll.printList()
ll.addAsRoot(1)
print("")
ll.deleteNodeAtNthPosition(6)
ll.printList()
print("Reversed List Follow")
ll.reverseList()
print("Reversed the List Again recursively: ")
ll.reverseListRecursive(ll.root)
ll.printList()