जब किसी विशिष्ट संख्या में नोड्स द्वारा दोहरी लिंक की गई सूची को घुमाने की आवश्यकता होती है, तो एक 'नोड' वर्ग बनाने की आवश्यकता होती है। इस वर्ग में, तीन विशेषताएं हैं, डेटा जो नोड में मौजूद है, लिंक की गई सूची के अगले नोड तक पहुंच और लिंक की गई सूची के पिछले नोड तक पहुंच है।
नीचे उसी के लिए एक प्रदर्शन है -
उदाहरण
class Node: def __init__(self, my_data): self.previous = None self.data = my_data self.next = None class double_list: def __init__(self): self.head = None self.tail = None self.size = 0 def add_data(self, my_data): new_node = Node(my_data) if(self.head == None): self.head = self.tail = new_node self.head.previous = None self.tail.next = None else: self.tail.next = new_node new_node.previous = self.tail self.tail = new_node self.tail.next = None self.size = self.size + 1; def print_it(self): curr = self.head if (self.head == None): print("The list is empty") return print("The nodes in the doubly linked list are :") while curr != None: print(curr.data) curr = curr.next def rotate_list(self, num): curr = self.head; if(num == 0 or num >= self.size): return; else: for i in range(1, num): curr = curr.next; self.tail.next = self.head; self.head = curr.next; self.head.previous = None; self.tail = curr; self.tail.next = None; my_instance = double_list() print("Elements are being added to the doubly linked list") my_instance.add_data(10) my_instance.add_data(24) my_instance.add_data(54) my_instance.add_data(77) my_instance.add_data(24) my_instance.add_data(0) my_instance.print_it() print("The elements in the list after rotating : ") my_instance.rotate_list(4) my_instance.print_it()
आउटपुट
Elements are being added to the doubly linked list The nodes in the doubly linked list are : 10 24 54 77 24 0 The elements in the list after rotating : The nodes in the doubly linked list are : 24 0 10 24 54 77
स्पष्टीकरण
- 'नोड' वर्ग बनाया गया है।
- आवश्यक विशेषताओं वाला एक और वर्ग बनाया गया है।
- 'add_data' नाम की एक अन्य विधि परिभाषित की गई है, जिसका उपयोग सर्कुलर लिंक्ड सूची में डेटा जोड़ने के लिए किया जाता है।
- 'रोटेट_लिस्ट' नामक एक अन्य विधि को परिभाषित किया गया है, जो विशिष्ट नोड को पिवट के रूप में उपयोग करती है और सूची को घुमाती है, जिससे तत्वों को एक अलग स्थिति में ले जाया जाता है।
- 'print_it' नामक एक अन्य विधि को परिभाषित किया गया है जिसका उपयोग कंसोल पर लिंक की गई सूची डेटा प्रदर्शित करने के लिए किया जाता है।
- 'डबल_लिस्ट' वर्ग का एक ऑब्जेक्ट बनाया जाता है, और उस पर डेटा जोड़ने के तरीकों को कहा जाता है।
- 'रोटेट_लिस्ट' विधि कहलाती है।
- यह लिंक की गई सूची में नोड्स के माध्यम से पुनरावृति करता है, सबसे मध्य सूचकांक प्राप्त करता है और तत्वों को हटाना शुरू करता है।
- यह 'print_it' पद्धति का उपयोग करके कंसोल पर प्रदर्शित होता है।