Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
98 changes: 98 additions & 0 deletions ReverseLinkList.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@

from sys import stdin, setrecursionlimit
setrecursionlimit(10 ** 6)

#Following is the Node class already written for the Linked List
class Node :
def __init__(self, data) :
self.data = data
self.next = None



#Iterative Approach
def Reverse(head):
curr = head
prev = None
while (curr is not None):
next = curr.next
curr.next = prev
prev = curr
curr = next
return prev #As our head is now prev






























#Taking Input Using Fast I/O
def takeInput() :
head = None
tail = None

datas = list(map(int, stdin.readline().rstrip().split(" ")))

i = 0
while (i < len(datas)) and (datas[i] != -1) :
data = datas[i]
newNode = Node(data)

if head is None:
head = newNode
tail = newNode

else :
tail.next = newNode
tail = newNode

i += 1

return head


#to print the linked list
def printLinkedList(head) :

while head is not None :
print(head.data, end = " ")
head = head.next

print()


#main
t = int(stdin.readline().rstrip())

while t > 0 :

head = takeInput()
head = Reverse(head)
printLinkedList(head)
print()

t -= 1