जब रिकर्सन की मदद से किसी लिंक की गई सूची के किसी विशिष्ट तत्व की घटना की संख्या की गणना करने की आवश्यकता होती है, तो लिंक की गई सूची में तत्वों को जोड़ने की एक विधि, लिंक की गई सूची के तत्वों को मुद्रित करने की एक विधि और गिनने की एक विधि लिंक की गई सूची में किसी तत्व की घटना को परिभाषित किया गया है। एक सहायक फ़ंक्शन परिभाषित किया गया है, क्योंकि रिकर्सन का उपयोग किया जा रहा है। यह सहायक फ़ंक्शन पहले से परिभाषित घटना गणना फ़ंक्शन को कॉल करता है।
नीचे उसी के लिए एक प्रदर्शन है -
उदाहरण
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 print_it(self):
curr = self.head
while curr:
print(curr.data)
curr = curr.next
def count_val(self, key):
return self.count_helper_fun(self.head, key)
def count_helper_fun(self, curr, key):
if curr is None:
return 0
if curr.data == key:
return 1 + self.count_helper_fun(curr.next, key)
else:
return self.count_helper_fun(curr.next, key)
my_instance = my_linked_list()
my_list = [56, 43, 70, 67, 89, 91, 70, 23, 46, 70]
for elem in my_list:
my_instance.add_value(elem)
print("The linked list contains the below elements:")
my_instance.print_it()
key_val = int(input('Enter the data item: '))
count_val = my_instance.count_val(key_val)
print('{0} occurs {1} time(s) in the list.'.format(key_val, count_val)) आउटपुट
The linked list contains the below elements: 56 43 70 67 89 91 70 23 46 70 Enter the data item: 70 70 occurs 3 time(s) in the list.
स्पष्टीकरण
-
'नोड' वर्ग बनाया गया है।
-
आवश्यक विशेषताओं के साथ एक और 'my_linked_list' वर्ग बनाया गया है।
-
इसमें एक 'init' फ़ंक्शन होता है जिसका उपयोग पहले तत्व को प्रारंभ करने के लिए किया जाता है, यानी 'हेड' से 'कोई नहीं' और अंतिम नोड को 'कोई नहीं'।
-
'add_value' नाम की एक अन्य विधि को परिभाषित किया गया है, जिसका उपयोग लिंक की गई सूची में डेटा जोड़ने के लिए किया जाता है।
-
'प्रिंट_इट' नामक एक अन्य विधि को परिभाषित किया गया है, जो सूची में पुनरावृत्त होती है, और तत्वों को प्रिंट करती है।
-
'काउंट_वल' नामक एक अन्य विधि को परिभाषित किया गया है जिसका उपयोग हेल्पर फ़ंक्शन को कॉल करने के लिए किया जाता है।
-
एक अन्य सहायक फ़ंक्शन, जिसका नाम 'count_helper_fun' है, को परिभाषित किया गया है, जो लिंक की गई सूची में किसी विशिष्ट तत्व की आवृत्ति को निर्धारित करने में मदद करता है।
-
'my_linked_list' वर्ग का एक ऑब्जेक्ट बनाया जाता है।
-
किसी विशिष्ट तत्व की आवृत्ति ज्ञात करने के लिए count_val विधि को कहा जाता है।
-
यह आउटपुट कंसोल पर प्रदर्शित होता है।