मुख्य सामग्री पर जाएं

Python लिंक्ड लिस्ट्स: उदाहरणों सहित ट्यूटोरियल

लिंक्ड लिस्ट्स के बारे में वह सब सीखें जो आपको जानना चाहिए: कब उपयोग करें, उनके प्रकार, और Python में उनका इम्प्लीमेंटेशन।
अद्यतन 2 जून 2026  · 9 मि॰ पढ़ना

लिंक्ड लिस्ट एक डेटा स्ट्रक्चर है जो डेटा के संगठन और प्रबंधन में अहम भूमिका निभाता है। इसमें नोड्स की एक शृंखला होती है जो मेमोरी में यादृच्छिक स्थानों पर संग्रहीत होती हैं, जिससे मेमोरी प्रबंधन कुशल रहता है। लिंक्ड लिस्ट के हर नोड में दो मुख्य घटक होते हैं: डेटा भाग और क्रम में अगले नोड का संदर्भ।

यदि यह अवधारणा पहली नज़र में जटिल लगे, तो चिंता न करें!

हम इसे मूल स्तर तक तोड़कर समझाएँगे कि लिंक्ड लिस्ट क्या हैं, हम उनका उपयोग क्यों करते हैं, और वे कौन से विशिष्ट लाभ देती हैं।

लिंक्ड लिस्ट क्यों?

लिंक्ड लिस्ट्स को साधारण लिस्ट्स और ऐरे में डेटा संग्रहीत करने से जुड़ी विभिन्न कमियों को दूर करने के लिए बनाया गया था, जैसा कि नीचे बताया गया है:

इंसर्शन और डिलीशन की आसानी

लिस्ट्स में, अंत के अलावा किसी भी स्थान पर तत्व जोड़ना या हटाना, उसके बाद आने वाले सभी आइटम्स को नए स्थान पर शिफ्ट करने की मांग करता है। इस प्रक्रिया की टाइम कॉम्प्लेक्सिटी O(n) होती है और विशेषकर लिस्ट का आकार बढ़ने पर प्रदर्शन पर नकारात्मक प्रभाव डाल सकती है। यदि आप पहले से लिस्ट्स कैसे काम करती हैं या उनका इम्प्लीमेंटेशन क्या है, उससे परिचित नहीं हैं, तो हमारा Python लिस्ट्स पर ट्यूटोरियल पढ़ सकते हैं।

वहीं, लिंक्ड लिस्ट अलग ढंग से काम करती है। वे तत्वों को अलग-अलग, असतत मेमोरी स्थानों में रखती हैं और उन्हें अगले नोड्स की ओर संकेत करने वाले पॉइंटर्स से जोड़ती हैं। यह संरचना लिंक्ड लिस्ट्स को किसी भी स्थान पर केवल लिंक्स संशोधित करके तत्व जोड़ने या हटाने की अनुमति देती है—नए तत्व को शामिल करने या हटाए गए को बायपास करने के लिए।

एक बार जब आपके पास इंसर्शन या डिलीशन पॉइंट वाले नोड का डायरेक्ट रेफरेंस हो, तो ऑपरेशन स्वयं O(1) होता है। फिर भी, उस स्थान तक पहुँचना O(n) ट्रैवर्सल मांगता है, इसलिए O(1) का लाभ तभी लागू होता है जब आपके पास पहले से संबंधित नोड का पॉइंटर हो (जैसे कि लिस्ट के हेड पर काम करते समय)।

डायनामिक साइज

Python लिस्ट्स डायनामिक ऐरे होती हैं, यानी वे आकार बदलने की लचीलापन देती हैं।

हालाँकि, इस प्रक्रिया में कई जटिल ऑपरेशंस शामिल होते हैं, जिनमें ऐरे को एक नए, बड़े मेमोरी ब्लॉक में रिऑलॉकेट करना भी शामिल है। ऐसी रिऑलॉकेशन अल्प-प्रभावी होती है क्योंकि तत्वों को नए ब्लॉक में कॉपी करना पड़ता है, जिससे तुरंत आवश्यक से अधिक स्पेस भी आवंटित हो सकता है।

इसके विपरीत, लिंक्ड लिस्ट्स बिना रिऑलॉकेशन या रीसाइजिंग के डायनामिक रूप से बढ़-घट सकती हैं। यह उन्हें उन कार्यों के लिए बेहतर विकल्प बनाता है जिनमें उच्च लचीलापन चाहिए।

मेमोरी दक्षता

लिस्ट्स अपने सभी तत्वों के लिए मेमोरी को एक सन्निहित (contiguous) ब्लॉक में आवंटित करती हैं। यदि लिस्ट को अपनी प्रारंभिक साइज से आगे बढ़ना हो, तो उसे नए, बड़े सन्निहित मेमोरी ब्लॉक का आवंटन करना पड़ता है और फिर सभी मौजूदा तत्वों को इस नए ब्लॉक में कॉपी करना पड़ता है। यह प्रक्रिया समय लेने वाली और अल्प-प्रभावी है, खासकर बड़ी लिस्ट्स के लिए। दूसरी ओर, यदि लिस्ट के प्रारंभिक आकार का अधिक अनुमान लगाया गया हो, तो अनुपयोगी मेमोरी बर्बाद होती है।

इसके विपरीत, लिंक्ड लिस्ट्स प्रत्येक तत्व के लिए अलग से मेमोरी आवंटित करती हैं। यह संरचना बेहतर मेमोरी उपयोगिता देती है क्योंकि नए तत्वों के लिए मेमोरी उन्हें जोड़ते समय ही आवंटित की जा सकती है।

लिंक्ड लिस्ट्स का उपयोग कब करें?

हालाँकि लिंक्ड लिस्ट्स डायनामिक साइज और मेमोरी दक्षता जैसे कुछ लाभ देती हैं, इनके भी सीमित पक्ष हैं। चूँकि प्रत्येक तत्व के लिए अगले नोड का संदर्भ रखने हेतु पॉइंटर स्टोर करना पड़ता है, इसलिए प्रति तत्व मेमोरी उपयोग लिंक्ड लिस्ट्स में अधिक होता है। साथ ही, यह डेटा स्ट्रक्चर डायरेक्ट एक्सेस की अनुमति नहीं देता। किसी तत्व तक पहुँचने के लिए लिस्ट की शुरुआत से क्रमिक ट्रैवर्सल करना पड़ता है, जिसका सर्च टाइम कॉम्प्लेक्सिटी O(n) होता है।

लिंक्ड लिस्ट या ऐरे का चुनाव एप्लिकेशन की विशिष्ट आवश्यकताओं पर निर्भर करता है। लिंक्ड लिस्ट्स सबसे उपयोगी तब होती हैं जब:

  • आपको बार-बार कई तत्व जोड़ने और हटाने की ज़रूरत हो
  • डेटा का आकार अप्रत्याशित हो या अक्सर बदलने की संभावना हो
  • तत्वों तक डायरेक्ट एक्सेस आवश्यक न हो
  • डेटासेट में बड़े तत्व या संरचनाएँ हों

लिंक्ड लिस्ट्स के प्रकार

लिंक्ड लिस्ट्स के तीन प्रकार होते हैं, जो अलग-अलग परिस्थितियों के लिए अलग लाभ प्रदान करते हैं। ये प्रकार हैं:

सिंगली-लिंक्ड लिस्ट्स

Image of a singly linked list

सिंगली-लिंक्ड लिस्ट

सिंगली-लिंक्ड लिस्ट सबसे सरल प्रकार है, जिसमें प्रत्येक नोड में कुछ डेटा और क्रम में अगले नोड का संदर्भ होता है। इन्हें केवल एक ही दिशा में ट्रैवर्स किया जा सकता है—हेड (पहला नोड) से टेल (अंतिम नोड) तक।

सिंगली-लिंक्ड लिस्ट में हर नोड आम तौर पर दो भागों से बना होता है:

  • डेटा: नोड में संग्रहीत वास्तविक जानकारी।
  • नेक्स्ट पॉइंटर: अगले नोड का संदर्भ। अंतिम नोड का नेक्स्ट पॉइंटर सामान्यतः null पर सेट होता है।

चूँकि इन डेटा स्ट्रक्चर्स को केवल एक दिशा में ट्रैवर्स किया जा सकता है, किसी विशिष्ट तत्व तक मान या इंडेक्स से पहुँचने के लिए हेड से शुरू करके मनचाहे नोड तक क्रमशः बढ़ना पड़ता है। इस ऑपरेशन की टाइम कॉम्प्लेक्सिटी O(n) होती है, जो बड़ी लिस्ट्स के लिए कम कुशल है।

सिंगली-लिंक्ड लिस्ट की शुरुआत में नोड जोड़ना और हटाना अत्यंत कुशल है, जिसकी टाइम कॉम्प्लेक्सिटी O(1) है। हालाँकि, बीच या अंत में इंसर्शन और डिलीशन के लिए उस बिंदु तक ट्रैवर्स करना पड़ता है, जिससे टाइम कॉम्प्लेक्सिटी O(n) हो जाती है।

सिंगली-लिंक्ड लिस्ट्स का डिज़ाइन उन्हें तब उपयोगी बनाता है जब ऑपरेशंस मुख्यतः लिस्ट की शुरुआत में होने हों।

डबल्ली-लिंक्ड लिस्ट्स

Image of a doubly linked list

डबल्ली-लिंक्ड लिस्ट

सिंगली-लिंक्ड लिस्ट्स की एक कमी यह है कि हम उन्हें केवल एक ही दिशा में ट्रैवर्स कर सकते हैं और आवश्यकता पड़ने पर पिछले नोड पर वापस नहीं जा सकते। यह बाधा उन ऑपरेशंस की क्षमता सीमित करती है जिन्हें दोनों दिशाओं में नेविगेशन चाहिए।

डबल्ली-लिंक्ड लिस्ट्स इस समस्या का समाधान हर नोड में एक अतिरिक्त पॉइंटर जोड़कर करती हैं, जिससे लिस्ट को दोनों दिशाओं में ट्रैवर्स किया जा सकता है। डबल्ली-लिंक्ड लिस्ट के प्रत्येक नोड में तीन तत्व होते हैं: डेटा, अगले नोड का पॉइंटर, और पिछले नोड का पॉइंटर।

सर्कुलर लिंक्ड लिस्ट्स

Image of a circular linked list

सर्कुलर लिंक्ड लिस्ट

सर्कुलर लिंक्ड लिस्ट्स लिंक्ड लिस्ट का एक विशेष रूप हैं जहाँ अंतिम नोड पहले नोड की ओर इशारा करता है, जिससे एक चक्रीय संरचना बनती है। यानी, अब तक देखी गई सिंगली और डबल्ली-लिंक्ड लिस्ट्स के विपरीत, सर्कुलर लिंक्ड लिस्ट समाप्त नहीं होती; बल्कि लूप करती रहती है।

सर्कुलर लिंक्ड लिस्ट्स की चक्रीय प्रकृति उन्हें उन परिदृश्यों के लिए आदर्श बनाती है जहाँ निरंतर लूपिंग की आवश्यकता होती है, जैसे बोर्ड गेम्स जो अंतिम खिलाड़ी से वापस पहले खिलाड़ी पर लौटते हैं, या कम्प्यूटिंग एल्गोरिदम जैसे राउंड-रॉबिन शेड्यूलिंग।

टाइम कॉम्प्लेक्सिटी सारांश

तेजी से तुलना करने के लिए यह देखना उपयोगी है कि लिंक्ड लिस्ट्स Python लिस्ट्स के मुकाबले कैसी हैं:

ऑपरेशन सिंगली लिंक्ड लिस्ट ऐरे/Python लिस्ट
इंडेक्स से एक्सेस O(n) O(1)
मान से खोज O(n) O(n)
शुरुआत में इंसर्ट O(1) O(n)
अंत में इंसर्ट O(n) O(1) अमोर्टाइज़्ड
बीच में इंसर्ट O(n) O(n)
शुरुआत से डिलीट O(1) O(n)
अंत से डिलीट O(n) O(1) अमोर्टाइज़्ड

मुख्य निष्कर्ष: लिंक्ड लिस्ट्स हेड पर इंसर्शन और डिलीशन में जीतती हैं (O(1)), लेकिन बाकी लगभग हर चीज़ में पीछे रह जाती हैं। यदि आप अपने डेटा स्ट्रक्चर की शुरुआत में बार-बार तत्व जोड़-हटा नहीं रहे हैं, तो सामान्य Python लिस्ट अधिकतर बेहतर चुनाव है।

Python में लिंक्ड लिस्ट कैसे बनाएं

अब जब हम समझ गए हैं कि लिंक्ड लिस्ट्स क्या हैं, क्यों उपयोग होती हैं, और उनके प्रकार क्या हैं, तो चलिए इन्हें Python में इम्प्लीमेंट करना सीखते हैं। इस ट्यूटोरियल का नोटबुक इस DataLab वर्कबुक में भी उपलब्ध है; यदि आप इसकी कॉपी बनाते हैं, तो कोड को संपादित और चला सकते हैं। यदि आपको अपने सिस्टम पर कोड चलाने में कोई दिक्कत आए, तो यह बढ़िया विकल्प है!

नोड को इनिशियलाइज़ करना

जैसा कि हमने पहले सीखा, नोड लिंक्ड लिस्ट का वह तत्व है जो डेटा और क्रम के अगले नोड का संदर्भ रखता है। Python में नोड को इस तरह परिभाषित कर सकते हैं:

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

    def __repr__(self):
        return f"Node({self.data})"

ऊपर दिया कोड दो मुख्य कार्रवाइयों के साथ एक नोड इनिशियलाइज़ करता है: नोड के “data” एट्रिब्यूट को वह मान सौंपा जाता है जो नोड में संग्रहीत वास्तविक जानकारी को दर्शाता है। “next” एट्रिब्यूट अगले नोड के एड्रेस का प्रतिनिधित्व करता है। अभी यह None पर सेट है, जो दर्शाता है कि यह लिस्ट में किसी अन्य नोड से लिंक नहीं है। जैसे-जैसे हम लिंक्ड लिस्ट में नए नोड्स जोड़ते जाएंगे, यह एट्रिब्यूट अगले नोड की ओर इंगित करने के लिए अपडेट होगा।

लिंक्ड लिस्ट क्लास बनाना

अगला कदम लिंक्ड लिस्ट क्लास बनाना है। यह नोड्स को मैनेज करने की सभी क्रियाओं—जैसे इंसर्शन और रिमूवल—को समेटेगा। हम लिंक्ड लिस्ट को इनिशियलाइज़ करने से शुरुआत करेंगे:

class LinkedList:
    def __init__(self):
        self.head = None  # Initialize head as None

self.head को None सेट करके, हम बता रहे हैं कि लिंक्ड लिस्ट शुरू में खाली है और किसी नोड की ओर इशारा नहीं कर रही। अब हम नए नोड्स डालकर लिस्ट को भरेंगे।

लिंक्ड लिस्ट की शुरुआत में नया नोड जोड़ना

LinkedList क्लास के भीतर हम एक मेथड जोड़ेंगे जो नया नोड बनाएगा और उसे लिस्ट की शुरुआत में रखेगा:

    def insertAtBeginning(self, new_data):
        new_node = Node(new_data)  # Create a new node 
        new_node.next = self.head  # Next for new node becomes the   current head
        self.head = new_node  # Head now points to the new node

हर बार जब आप ऊपर दिए मेथड को कॉल करेंगे, आपके निर्दिष्ट डेटा के साथ एक नया नोड बनेगा। इस नए नोड का नेक्स्ट पॉइंटर लिस्ट के मौजूदा हेड पर सेट होगा, जिससे यह नोड मौजूदा नोड्स के आगे आ जाएगा। अंततः, नया नोड लिस्ट का हेड बन जाएगा।

अब हम इंसर्शन ऑपरेशन कैसे काम करता है, यह बेहतर समझने के लिए कुछ शब्द जोड़कर इस लिंक्ड लिस्ट को भरेंगे। इसे करने के लिए, पहले एक मेथड बनाते हैं जो लिस्ट को ट्रैवर्स करके उसकी सामग्री प्रिंट करे:

    def printList(self):
        temp = self.head # Start from the head of the list
        while temp:
            print(temp.data,end=' ') # Print the data in the current node
            temp = temp.next # Move to the next node
        print()  # Ensures the output is followed by a new line

यह मेथड हमारी लिंक्ड लिस्ट की सामग्री प्रिंट करेगा। अब हम उन्हीं मेथड्स का उपयोग करके अपनी लिस्ट को इन शब्दों से भरेंगे: “the quick brown fox.”

if __name__ == '__main__':
    # Create a new LinkedList instance
    llist = LinkedList()

    # Insert each letter at the beginning using the method we created
    llist.insertAtBeginning('fox') 
    llist.insertAtBeginning('brown') 
    llist.insertAtBeginning('quick')  
    llist.insertAtBeginning('the')  

    # Now 'the' is the head of the list, followed by 'quick', then 'brown' and 'fox'

    # Print the list
    llist.printList()

ऊपर दिया कोड निम्नलिखित आउटपुट दिखाएगा:

"the quick brown fox"

लिंक्ड लिस्ट के अंत में नया नोड जोड़ना

अब हम LinkedList क्लास के भीतर insertAtEnd नामक एक मेथड बनाएँगे, जो लिस्ट के अंत में नया नोड बनाएगा। यदि लिस्ट खाली है, तो नया नोड लिस्ट का हेड बन जाएगा। अन्यथा, यह लिस्ट के मौजूदा आखिरी नोड से जुड़ जाएगा। देखते हैं यह व्यवहार में कैसे काम करता है:

    def insertAtEnd(self, new_data):
        new_node = Node(new_data)
        if self.head is None:
            self.head = new_node
            return
        last = self.head
        while last.next:
            last = last.next
        last.next = new_node

यह मेथड पहले नया नोड बनाता है। फिर जाँचता है कि लिस्ट खाली है या नहीं; यदि हाँ, तो नया नोड लिस्ट का हेड बना दिया जाता है। अन्यथा, यह लिस्ट को ट्रैवर्स कर आखिरी नोड ढूँढता है और उस नोड के पॉइंटर को नए नोड पर सेट करता है।

अब हमें इस मेथड को अपनी LinkedList क्लास में शामिल करना है और इसका उपयोग करके सूची के अंत में एक शब्द जोड़ना है। इसके लिए अपनी मुख्य फ़ंक्शन को इस तरह संशोधित करें:

if __name__ == '__main__':
    llist = LinkedList()

    # Insert words at the beginning
    llist.insertAtBeginning('fox')
    llist.insertAtBeginning('brown')
    llist.insertAtBeginning('quick')
    llist.insertAtBeginning('the')

    # Insert a word at the end
    llist.insertAtEnd('jumps')

    # Print the list
    llist.printList()

ध्यान दें कि हमने बस insertAtEnd मेथड को कॉल करके लिस्ट के अंत में “jumps” शब्द जोड़ दिया है। ऊपर दिया कोड निम्नलिखित आउटपुट दिखाएगा:

"the quick brown fox jumps"

लिंक्ड लिस्ट की शुरुआत से नोड हटाना

लिंक्ड लिस्ट के पहले नोड को हटाना आसान है क्योंकि इसमें केवल लिस्ट के हेड को दूसरे नोड की ओर इंगित करना होता है। इस तरह पहला नोड लिस्ट का हिस्सा नहीं रहता। इसके लिए LinkedList क्लास में नीचे दिया मेथड जोड़ें:

def deleteFromBeginning(self):
    if self.head is None:
        return "The list is empty" # If the list is empty, return this string
    self.head = self.head.next  # Otherwise, remove the head by making the next node the new head

लिंक्ड लिस्ट के अंत से नोड हटाना

लिंक्ड लिस्ट के आखिरी नोड को हटाने के लिए, हमें लिस्ट को ट्रैवर्स करके दूसरे-आखिरी नोड तक पहुँचना होगा और उसके नेक्स्ट पॉइंटर को None करना होगा। इस तरह आखिरी नोड लिस्ट का हिस्सा नहीं रहेगा। इसे करने के लिए अपने LinkedList क्लास में नीचे दिया मेथड जोड़ें:

def deleteFromEnd(self):
    if self.head is None:
        return "The list is empty" 
    if self.head.next is None:
        self.head = None  # If there's only one node, remove the head by making it None
        return
    temp = self.head
    while temp.next.next:  # Otherwise, go to the second-last node
        temp = temp.next
    temp.next = None  # Remove the last node by setting the next pointer of the second-last node to None

यह मेथड पहले जाँचता है कि लिंक्ड लिस्ट खाली है या नहीं; यदि हाँ, तो यह उपयोगकर्ता को संदेश लौटाता है। अन्यथा, यदि लिस्ट में केवल एक नोड है, तो वह नोड हटा दिया जाता है। कई नोड्स वाली लिस्ट्स के लिए, यह मेथड दूसरे-आखिरी नोड को खोजता है और उसके नेक्स्ट रेफरेंस को None कर देता है।

अब हम मुख्य फ़ंक्शन को अपडेट करेंगे ताकि लिंक्ड लिस्ट की शुरुआत और अंत से तत्व हटाए जा सकें:

if __name__ == '__main__':
    llist = LinkedList()

    # Insert words at the beginning
    llist.insertAtBeginning('fox')
    llist.insertAtBeginning('brown')
    llist.insertAtBeginning('quick')
    llist.insertAtBeginning('the')

    # Insert a word at the end
    llist.insertAtEnd('jumps')

    # Print the list before deletion
    print("List before deletion:")
    llist.printList()

    # Deleting nodes from the beginning and end
    llist.deleteFromBeginning()
    llist.deleteFromEnd()

    # Print the list after deletion
    print("List after deletion:")
    llist.printList()

ऊपर दिया कोड डिलीशन से पहले और बाद की लिस्ट प्रिंट करेगा, जिससे लिंक्ड लिस्ट्स में इंसर्ट और डिलीट ऑपरेशंस कैसे काम करते हैं, यह स्पष्ट होगा। इस कोड को चलाने पर आपको निम्नलिखित आउटपुट दिखना चाहिए:

List before deletion:
the quick brown fox jumps 
List after deletion:
quick brown fox

लिंक्ड लिस्ट में किसी विशिष्ट मान की खोज

इस अध्याय का अंतिम ऑपरेशन लिंक्ड लिस्ट में किसी विशिष्ट मान को खोजना है। इसके लिए मेथड को लिस्ट के हेड से शुरू कर प्रत्येक नोड से गुजरते हुए जाँचना चाहिए कि क्या नोड का डेटा सर्च वैल्यू से मेल खाता है। इस ऑपरेशन का एक व्यवहारिक इम्प्लीमेंटेशन नीचे है:

def search(self, value):
    current = self.head  # Start with the head of the list
    position = 0  # Counter to keep track of the position
    while current: # Traverse the list
        if current.data == value: # Compare the list's data to the search value
            return f"Value '{value}' found at position {position}" # Print the value if a match is found
        current = current.next
        position += 1
    return f"Value '{value}' not found in the list" 

हमारी बनाई लिंक्ड लिस्ट में विशिष्ट मान ढूँढने के लिए, अभी बनाए गए सर्च मेथड को अपने मुख्य फ़ंक्शन में शामिल करें:

if __name__ == '__main__':
    llist = LinkedList()

    # Insert words at the beginning
    llist.insertAtBeginning('fox')
    llist.insertAtBeginning('brown')
    llist.insertAtBeginning('quick')
    llist.insertAtBeginning('the')

    # Insert a word at the end
    llist.insertAtEnd('jumps')

   # Print the list before deletion
    print("List before deletion:")
    llist.printList()

    # Deleting nodes from beginning and end
    llist.deleteFromBeginning()
    llist.deleteFromEnd()

    # Print the list after deletion
    print("List after deletion:")
    llist.printList()
    
        # Search for 'quick' and 'lazy' in the list
    print(llist.search('quick'))  # Expected to find
    print(llist.search('lazy'))   # Expected not to find

ऊपर दिया कोड निम्नलिखित आउटपुट दिखाएगा:

List before deletion:
the quick brown fox jumps 
List after deletion:
quick brown fox 
Value 'quick' found at position 0
Value 'lazy' not found in the list

“quick” शब्द सफलतापूर्वक लिंक्ड लिस्ट में मिल गया है क्योंकि वह लिस्ट की पहली पोज़िशन पर मौजूद है। वहीं “lazy” लिस्ट का हिस्सा नहीं है, इसलिए वह नहीं मिला।

अंतिम विचार

यदि आप यहाँ तक पहुँचे हैं, तो बधाई! अब आपको लिंक्ड लिस्ट्स की बुनियादी सिद्धांतों—उनकी संरचना, प्रकार, तत्व जोड़ना-हटाना, और ट्रैवर्स करना—की मजबूत समझ है।

लेकिन सफ़र यहीं खत्म नहीं होता। लिंक्ड लिस्ट्स डेटा स्ट्रक्चर्स और एल्गोरिदम की दुनिया की बस शुरुआत हैं। विषय की समझ गहरी करने के लिए आपके लिए कुछ संभावित अगले कदम यहाँ हैं:

अपना प्रोजेक्ट बनाएँ

लिंक्ड लिस्ट्स के व्यावहारिक उपयोगों में उतरें—उन्हें किसी कोडिंग या डेटा साइंस प्रोजेक्ट में शामिल करके। लिंक्ड लिस्ट्स का उपयोग फ़ाइल सिस्टम विकसित करने, हैश टेबल बनाने, यहाँ तक कि GPS नेविगेशन सिस्टम और बोर्ड गेम्स बनाने में होता है। अपने प्रोजेक्ट्स शुरू करने के लिए, हमारे निःशुल्क गाइडेड डेटा साइंस प्रोजेक्ट्स देखें जो आपको Python, R और SQL में वास्तविक समस्याएँ सुलझाना सिखाते हैं।

डेटा स्ट्रक्चर्स और एल्गोरिदम सीखें

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

यदि ये अवधारणाएँ आपको अनजानी लगती हैं, तो चिंता न करें! Datacamp के पास Python में डेटा स्ट्रक्चर्स और एल्गोरिदम पर पूरा कोर्स है जो आपको इन अवधारणाओं से विस्तार से परिचित कराएगा। आप पहले स्टैक्स, ट्रीज़, हैश टेबल्स, क्यूज़ और ग्राफ़्स जैसे डेटा स्ट्रक्चर्स के बारे में सीखेंगे। कोर्स में आगे बढ़ते हुए, आप सर्चिंग और सॉर्टिंग एल्गोरिदम समझेंगे, जो आपको अधिक दक्ष प्रोग्रामर और समस्या-समाधानकर्ता बनने में मदद करेंगे।

एडवांस्ड लिंक्ड लिस्ट अवधारणाएँ

हमने इस ट्यूटोरियल में सिंगली-लिंक्ड लिस्ट्स इम्प्लीमेंट की हैं, और इंसर्शन, डिलीशन, तथा ट्रैवर्सल जैसे ऑपरेशंस कवर किए हैं।

आप इस ज्ञान को एक कदम आगे ले जाकर डबल्ली और सर्कुलर लिंक्ड लिस्ट्स का इम्प्लीमेंटेशन सीख सकते हैं। स्किप लिस्ट्स लिंक्ड लिस्ट्स का एक और विस्तार हैं जो तेज़ सर्च ऑपरेशंस की सुविधा देते हैं, क्योंकि वे तत्वों तक शीघ्र पहुँच सक्षम करते हैं।

इन उन्नत डेटा स्ट्रक्चर्स के बारे में सीखना आपकी तकनीकी क्षमताओं को अगले स्तर पर ले जाएगा और आपकी प्रोग्रामिंग योग्यता में बड़ा सुधार करेगा, जिससे आप डेटा साइंस, सॉफ्टवेयर डेवलपमेंट और मशीन लर्निंग इंजीनियरिंग जैसे क्षेत्रों में अधिक जटिल चुनौतियों के लिए तैयार होंगे।

यदि आप इन उन्नत विषयों से पहले प्रोग्रामिंग की अधिक शुरुआती-अनुकूल शुरुआत चाहते हैं, तो हमारा Python Programmer करियर ट्रैक देखें। इसमें पाठ्यक्रमों की एक शृंखला है जो आपको भाषा की बुनियाद सिखाएगी।

विषय

Python सीखते रहें!

Track

Python डेटा मूलभूत बातें

28 घंटा
अपने डेटा कौशल बढ़ाएँ, डेटा को हेरफेर और विज़ुअलाइज़ करना सीखें, और डेटा-आधारित निर्णय लेने के लिए उन्नत विश्लेषण लागू करें।
विस्तृत जानकारी देखेंRight Arrow
कोर्स शुरू करें

Track

Python प्रोग्रामिंग

19 घंटा
अपने प्रोग्रामिंग कौशल को बेहतर बनाएं। कोड को अनुकूलित करना, फ़ंक्शन और परीक्षण लिखना, और सर्वोत्तम-अभ्यास सॉफ़्टवेयर इंजीनियरिंग तकनीकों का उपयोग करना सीखें।
और देखेंRight Arrow