पायथन - लिंक्ड सूची
एक लिंक की गई सूची डेटा तत्वों का एक अनुक्रम है, जो लिंक के माध्यम से एक साथ जुड़े हुए हैं। प्रत्येक डेटा तत्व में सूचक के रूप में किसी अन्य डेटा तत्व का कनेक्शन होता है। पायथन में अपने मानक पुस्तकालय में लिंक की गई सूची नहीं है। हम पिछले अध्याय में चर्चा की गई नोड्स की अवधारणा का उपयोग करके लिंक की गई सूचियों की अवधारणा को लागू करते हैं। हमने पहले ही देखा है कि हम एक नोड वर्ग कैसे बनाते हैं और नोड के तत्वों को कैसे पार करते हैं। इस अध्याय में हम जुड़े हुए सूचियों के प्रकारों का अध्ययन करने जा रहे हैं, जिन्हें एकवचन से जुड़ी सूचियों के रूप में जाना जाता है। इस प्रकार की डेटा संरचना में किन्हीं दो डेटा तत्वों के बीच केवल एक लिंक होता है। हम ऐसी सूची बनाते हैं और सूची से तत्वों को सम्मिलित करने, अद्यतन करने और हटाने के लिए अतिरिक्त तरीके बनाते हैं।
लिंक्ड सूची का निर्माण
पिछले अध्याय में हमने जिस नोड क्लास का अध्ययन किया है, उसका उपयोग करके एक लिंक की गई सूची बनाई गई है। हम एक नोड ऑब्जेक्ट बनाते हैं और इस ode ऑब्जेक्ट का उपयोग करने के लिए एक अन्य वर्ग बनाते हैं। हम अगले डेटा तत्वों को इंगित करने के लिए नोड ऑब्जेक्ट को उचित मानों को पास करते हैं। नीचे दिया गया प्रोग्राम तीन डेटा तत्वों के साथ लिंक की गई सूची बनाता है। अगले भाग में हम देखेंगे कि लिंक की गई सूची को कैसे पार किया जाए।
class Node:
def __init__(self, dataval=None):
self.dataval = dataval
self.nextval = None
class SLinkedList:
def __init__(self):
self.headval = None
list1 = SLinkedList()
list1.headval = Node("Mon")
e2 = Node("Tue")
e3 = Node("Wed")
# Link first Node to second node
list1.headval.nextval = e2
# Link second Node to third node
e2.nextval = e3
लिंक की गई सूची को पार करना
पहली डेटा तत्व के रूप में एकल लिंक की गई सूचियों को केवल फॉरवर्ड दिशा में ट्रेस किया जा सकता है। हम केवल वर्तमान डेटा तत्व के लिए अगले नोड के पॉइंटर को असेंबल करके अगले डेटा तत्व के मूल्य को प्रिंट करते हैं।
class Node:
def __init__(self, dataval=None):
self.dataval = dataval
self.nextval = None
class SLinkedList:
def __init__(self):
self.headval = None
def listprint(self):
printval = self.headval
while printval is not None:
print (printval.dataval)
printval = printval.nextval
list = SLinkedList()
list.headval = Node("Mon")
e2 = Node("Tue")
e3 = Node("Wed")
# Link first Node to second node
list.headval.nextval = e2
# Link second Node to third node
e2.nextval = e3
list.listprint()
जब उपरोक्त कोड निष्पादित होता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है:
Mon
Tue
Wed
एक लिंक्ड सूची में प्रविष्टि
लिंक की गई सूची में तत्व सम्मिलित करने से इंगितकर्ताओं को मौजूदा नोड्स से नए सम्मिलित नोड में पुन: असाइन करना शामिल है। इस बात पर निर्भर करता है कि नया डेटा तत्व शुरुआत में या बीच में या लिंक की गई सूची के अंत में डाला जा रहा है, हमारे पास नीचे के परिदृश्य हैं।
लिंक्ड सूची की शुरुआत में सम्मिलित करना
इसमें लिंक किए गए सूची के वर्तमान प्रमुख पर नए डेटा नोड के अगले पॉइंटर को इंगित करना शामिल है। तो लिंक की गई सूची का वर्तमान प्रमुख दूसरा डेटा तत्व बन जाता है और नया नोड लिंक्ड सूची का प्रमुख बन जाता है।
class Node:
def __init__(self, dataval=None):
self.dataval = dataval
self.nextval = None
class SLinkedList:
def __init__(self):
self.headval = None
# Print the linked list
def listprint(self):
printval = self.headval
while printval is not None:
print (printval.dataval)
printval = printval.nextval
def AtBegining(self,newdata):
NewNode = Node(newdata)
# Update the new nodes next val to existing node
NewNode.nextval = self.headval
self.headval = NewNode
list = SLinkedList()
list.headval = Node("Mon")
e2 = Node("Tue")
e3 = Node("Wed")
list.headval.nextval = e2
e2.nextval = e3
list.AtBegining("Sun")
list.listprint()
जब उपरोक्त कोड निष्पादित होता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है:
Sun
Mon
Tue
Wed
लिंक्ड सूची के अंत में सम्मिलित करना
इसमें लिंक किए गए सूची के वर्तमान अंतिम नोड के नए डेटा नोड के अगले सूचक को इंगित करना शामिल है। तो लिंक की गई सूची का वर्तमान अंतिम नोड दूसरा अंतिम डेटा नोड बन जाता है और नया नोड लिंक किए गए सूची का अंतिम नोड बन जाता है।
class Node:
def __init__(self, dataval=None):
self.dataval = dataval
self.nextval = None
class SLinkedList:
def __init__(self):
self.headval = None
# Function to add newnode
def AtEnd(self, newdata):
NewNode = Node(newdata)
if self.headval is None:
self.headval = NewNode
return
laste = self.headval
while(laste.nextval):
laste = laste.nextval
laste.nextval=NewNode
# Print the linked list
def listprint(self):
printval = self.headval
while printval is not None:
print (printval.dataval)
printval = printval.nextval
list = SLinkedList()
list.headval = Node("Mon")
e2 = Node("Tue")
e3 = Node("Wed")
list.headval.nextval = e2
e2.nextval = e3
list.AtEnd("Thu")
list.listprint()
जब उपरोक्त कोड निष्पादित होता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है:
Mon
Tue
Wed
Thu
दो डेटा नोड्स के बीच में सम्मिलित करना
इसमें नए नोड को इंगित करने के लिए एक विशिष्ट नोड के पॉइंटर को बदलना शामिल है। यह नए नोड और मौजूदा नोड दोनों में पारित होने के बाद संभव है जिसके बाद नया नोड डाला जाएगा। तो हम एक अतिरिक्त वर्ग को परिभाषित करते हैं जो नए नोड के अगले पॉइंटर को मध्य नोड के अगले पॉइंटर में बदल देगा। फिर नए नोड को मध्य नोड के अगले पॉइंटर को असाइन करें।
class Node:
def __init__(self, dataval=None):
self.dataval = dataval
self.nextval = None
class SLinkedList:
def __init__(self):
self.headval = None
# Function to add node
def Inbetween(self,middle_node,newdata):
if middle_node is None:
print("The mentioned node is absent")
return
NewNode = Node(newdata)
NewNode.nextval = middle_node.nextval
middle_node.nextval = NewNode
# Print the linked list
def listprint(self):
printval = self.headval
while printval is not None:
print (printval.dataval)
printval = printval.nextval
list = SLinkedList()
list.headval = Node("Mon")
e2 = Node("Tue")
e3 = Node("Thu")
list.headval.nextval = e2
e2.nextval = e3
list.Inbetween(list.headval.nextval,"Fri")
list.listprint()
जब उपरोक्त कोड निष्पादित होता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है:
Mon
Tue
Fri
Thu
किसी आइटम को निकालकर पसंद की गई सूची
हम उस नोड के लिए कुंजी का उपयोग करके एक मौजूदा नोड को निकाल सकते हैं। नीचे दिए गए कार्यक्रम में हम उस नोड के पिछले नोड का पता लगाते हैं जिसे हटाना है। फिर इस नोड के अगले पॉइंटर को हटाए जाने वाले नोड के अगले नोड पर इंगित करें।
class Node:
def __init__(self, data=None):
self.data = data
self.next = None
class SLinkedList:
def __init__(self):
self.head = None
def Atbegining(self, data_in):
NewNode = Node(data_in)
NewNode.next = self.head
self.head = NewNode
# Function to remove node
def RemoveNode(self, Removekey):
HeadVal = self.head
if (HeadVal is not None):
if (HeadVal.data == Removekey):
self.head = HeadVal.next
HeadVal = None
return
while (HeadVal is not None):
if HeadVal.data == Removekey:
break
prev = HeadVal
HeadVal = HeadVal.next
if (HeadVal == None):
return
prev.next = HeadVal.next
HeadVal = None
def LListprint(self):
printval = self.head
while (printval):
print(printval.data),
printval = printval.next
llist = SLinkedList()
llist.Atbegining("Mon")
llist.Atbegining("Tue")
llist.Atbegining("Wed")
llist.Atbegining("Thu")
llist.RemoveNode("Tue")
llist.LListprint()
जब उपरोक्त कोड निष्पादित होता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है:
Thu
Wed
Mon