पायथन - उन्नत लिंक्ड सूची

हमने पहले से ही पहले अध्याय में लिंक्ड सूची देखी है जिसमें केवल आगे की यात्रा संभव है। इस अध्याय में हम एक अन्य प्रकार की लिंक्ड सूची देखते हैं जिसमें आगे और पीछे दोनों ओर यात्रा संभव है। इस तरह की लिंक्ड लिस्ट को Doubly Linked List कहा जाता है। इसके बाद दोगुनी लिंक्ड सूची की विशेषताएं हैं।

  • Doubly Linked List में पहले और अंतिम नाम का एक लिंक तत्व होता है।
  • प्रत्येक लिंक एक डेटा फ़ील्ड (ओं) और दो लिंक फ़ील्ड्स को ले जाता है जिसे अगले और मौजूदा कहा जाता है।
  • प्रत्येक लिंक अपने अगले लिंक का उपयोग करके अपने अगले लिंक के साथ जुड़ा हुआ है।
  • प्रत्येक लिंक अपने पिछले लिंक का उपयोग करके अपने पिछले लिंक से जुड़ा हुआ है।
  • अंतिम लिंक सूची के अंत को चिह्नित करने के लिए एक लिंक को अशक्त करता है।

डबली लिंक्ड सूची बनाना

हम नोड क्लास का उपयोग करके एक डबली लिंक्ड सूची बनाते हैं। अब हम उसी दृष्टिकोण का उपयोग करते हैं जैसा कि Singly Linked List में किया जाता है लेकिन सिर और अगले पॉइंटर्स का उपयोग नोड में मौजूद डेटा के अलावा प्रत्येक नोड में दो लिंक बनाने के लिए उचित असाइनमेंट के लिए किया जाएगा।

class Node:
   def __init__(self, data):
      self.data = data
      self.next = None
      self.prev = None

class doubly_linked_list:

   def __init__(self):
      self.head = None

# Adding data elements		
   def push(self, NewVal):
      NewNode = Node(NewVal)
      NewNode.next = self.head
      if self.head is not None:
         self.head.prev = NewNode
      self.head = NewNode

# Print the Doubly Linked list		
   def listprint(self, node):
      while (node is not None):
         print(node.data),
         last = node
         node = node.next

dllist = doubly_linked_list()
dllist.push(12)
dllist.push(8)
dllist.push(62)
dllist.listprint(dllist.head)

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

62 8 12

डबली लिंक्ड सूची में सम्मिलित करना

यहां हम यह देखने जा रहे हैं कि निम्नलिखित प्रोग्राम का उपयोग करके नोड लिंक सूची में नोड कैसे डाला जाए। कार्यक्रम एक मेन्थोड नाम का उपयोग करता है जो दोहरे लिंक की गई सूची के प्रमुख से तीसरे स्थान पर नया नोड सम्मिलित करता है।

# Create the Node class
class Node:
   def __init__(self, data):
      self.data = data
      self.next = None
      self.prev = None

# Create the doubly linked list
class doubly_linked_list:

   def __init__(self):
      self.head = None

# Define the push method to add elements		
   def push(self, NewVal):

      NewNode = Node(NewVal)
      NewNode.next = self.head
      if self.head is not None:
         self.head.prev = NewNode
      self.head = NewNode

# Define the insert method to insert the element		
   def insert(self, prev_node, NewVal):
      if prev_node is None:
         return
      NewNode = Node(NewVal)
      NewNode.next = prev_node.next
      prev_node.next = NewNode
      NewNode.prev = prev_node
      if NewNode.next is not None:
         NewNode.next.prev = NewNode

# Define the method to print the linked list 
   def listprint(self, node):
      while (node is not None):
         print(node.data),
         last = node
         node = node.next

dllist = doubly_linked_list()
dllist.push(12)
dllist.push(8)
dllist.push(62)
dllist.insert(dllist.head.next, 13)
dllist.listprint(dllist.head)

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

62  8  13  12

संदेह से जुड़ी सूची में आवेदन करना

दोगुनी लिंक की गई सूची में लागू होने से अंत में तत्व जुड़ जाएगा।

# Create the node class
class Node:
   def __init__(self, data):
      self.data = data
      self.next = None
      self.prev = None
# Create the doubly linked list class
class doubly_linked_list:

   def __init__(self):
      self.head = None

# Define the push method to add elements at the begining
   def push(self, NewVal):
      NewNode = Node(NewVal)
      NewNode.next = self.head
      if self.head is not None:
         self.head.prev = NewNode
      self.head = NewNode

# Define the append method to add elements at the end
   def append(self, NewVal):

      NewNode = Node(NewVal)
      NewNode.next = None
      if self.head is None:
         NewNode.prev = None
         self.head = NewNode
         return
      last = self.head
      while (last.next is not None):
         last = last.next
      last.next = NewNode
      NewNode.prev = last
      return

# Define the method to print
   def listprint(self, node):
      while (node is not None):
         print(node.data),
         last = node
         node = node.next

dllist = doubly_linked_list()
dllist.push(12)
dllist.append(9)
dllist.push(8)
dllist.push(62)
dllist.append(45)
dllist.listprint(dllist.head)

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

62 8 12 9 45

कृपया परिशिष्ट ऑपरेशन के लिए तत्वों की स्थिति ९ और ४५ पर ध्यान दें।