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

एक लिंक की गई सूची डेटा तत्वों का एक अनुक्रम है, जो लिंक के माध्यम से एक साथ जुड़े हुए हैं। प्रत्येक डेटा तत्व में सूचक के रूप में किसी अन्य डेटा तत्व का कनेक्शन होता है। पायथन में अपने मानक पुस्तकालय में लिंक की गई सूची नहीं है। हम पिछले अध्याय में चर्चा की गई नोड्स की अवधारणा का उपयोग करके लिंक की गई सूचियों की अवधारणा को लागू करते हैं। हमने पहले ही देखा है कि हम एक नोड वर्ग कैसे बनाते हैं और नोड के तत्वों को कैसे पार करते हैं। इस अध्याय में हम जुड़े हुए सूचियों के प्रकारों का अध्ययन करने जा रहे हैं, जिन्हें एकवचन से जुड़ी सूचियों के रूप में जाना जाता है। इस प्रकार की डेटा संरचना में किन्हीं दो डेटा तत्वों के बीच केवल एक लिंक होता है। हम ऐसी सूची बनाते हैं और सूची से तत्वों को सम्मिलित करने, अद्यतन करने और हटाने के लिए अतिरिक्त तरीके बनाते हैं।

लिंक्ड सूची का निर्माण

पिछले अध्याय में हमने जिस नोड क्लास का अध्ययन किया है, उसका उपयोग करके एक लिंक की गई सूची बनाई गई है। हम एक नोड ऑब्जेक्ट बनाते हैं और इस 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