যখন পুনরাবৃত্তির পদ্ধতি ব্যবহার না করে একটি লিঙ্ক করা তালিকার নোডগুলিকে বিপরীতভাবে প্রদর্শন করার প্রয়োজন হয়, লিঙ্ক করা তালিকায় উপাদানগুলি যোগ করার একটি পদ্ধতি এবং উপাদানগুলিকে বিপরীত ক্রমে প্রদর্শন করার একটি পদ্ধতি সংজ্ঞায়িত করা হয়৷
নীচে একই −
এর জন্য একটি প্রদর্শন রয়েছে৷উদাহরণ
class Node:
def __init__(self, data):
self.data = data
self.next = None
class my_linked_list:
def __init__(self):
self.head = None
self.last_node = None
def add_value(self, my_data):
if self.last_node is None:
self.head = Node(my_data)
self.last_node = self.head
else:
self.last_node.next = Node(my_data)
self.last_node = self.last_node.next
def reverse_display(self):
end_node = None
while end_node != self.head:
curr = self.head
while curr.next != end_node:
curr = curr.next
print(curr.data)
end_node = curr
my_instance = my_linked_list()
n = int(input('How many elements you wish to add ? '))
for i in range(n):
data = int(input('Enter a data item : '))
my_instance.add_value(data)
print('The reversed linked list is : ')
my_instance.reverse_display() আউটপুট
How many elements you wish to add ? 5 Enter a data item : 43 Enter a data item : 67 Enter a data item : 87 Enter a data item : 12 Enter a data item : 34 The reversed linked list is : 34 12 87 67 43
ব্যাখ্যা
-
'নোড' ক্লাস তৈরি করা হয়েছে।
-
প্রয়োজনীয় গুণাবলী সহ আরেকটি 'my_linked_list' ক্লাস তৈরি করা হয়েছে।
-
এটির একটি 'init' ফাংশন রয়েছে যা প্রথম উপাদানটি শুরু করতে ব্যবহৃত হয়, যেমন 'হেড' থেকে 'কোনও নয়' এবং শেষ নোড থেকে 'কোনটি নয়'।
-
'add_value' নামের আরেকটি পদ্ধতি সংজ্ঞায়িত করা হয়েছে, যেটি লিঙ্ক করা তালিকায় ডেটা যোগ করতে ব্যবহৃত হয়।
-
'রিভার্স_ডিসপ্লে' নামে আরেকটি পদ্ধতি সংজ্ঞায়িত করা হয়েছে যা কনসোলে লিঙ্ক করা তালিকার ডেটা বিপরীত ক্রমে প্রদর্শন করতে ব্যবহৃত হয়।
-
'my_linked_list' ক্লাসের একটি অবজেক্ট তৈরি করা হয়েছে।
-
লিঙ্ক করা তালিকার উপাদানের সংখ্যার জন্য ব্যবহারকারীর ইনপুট নেওয়া হয়।
-
এই পরিসরটি পুনরাবৃত্তি করা হয়, এবং ডেটা যোগ করার জন্য পদ্ধতিগুলিকে বলা হয়৷
৷ -
উপাদানগুলিকে 'রিভার্স_ডিসপ্লে' ব্যবহার করে বিপরীত করা হয় এবং কনসোলে প্রদর্শিত হয়।