अजगर - बाइनरी ट्री

ट्री किनारों द्वारा जुड़े नोड्स का प्रतिनिधित्व करता है। यह एक गैर-रेखीय डेटा संरचना है। इसके निम्नलिखित गुण हैं।

  • एक नोड को रूट नोड के रूप में चिह्नित किया गया है।
  • जड़ के अलावा हर नोड एक मूल नोड के साथ जुड़ा हुआ है।
  • प्रत्येक नोड में chid नोड का एक arbiatry नंबर हो सकता है।

हम पहले चर्चा की गई ओएस ओएस नोड का उपयोग करके अजगर में एक पेड़ डेटा संरचना बनाते हैं। हम एक नोड को रूट नोड के रूप में नामित करते हैं और फिर बच्चे नोड्स के रूप में अधिक नोड जोड़ते हैं। नीचे रूट नोड बनाने का कार्यक्रम है।

रूट बनाएँ

हम सिर्फ एक नोड वर्ग बनाते हैं और नोड में एक मान जोड़ते हैं। यह केवल रूट नोड वाला पेड़ बन जाता है।

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data


    def PrintTree(self):
        print(self.data)

root = Node(10)

root.PrintTree()

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

10

एक पेड़ में घुसना

एक पेड़ में डालने के लिए हम ऊपर बनाए गए समान नोड वर्ग का उपयोग करते हैं और इसमें एक सम्मिलित विधि जोड़ते हैं। डालने की विधि नोड के मान की तुलना नोड नोड से करती है और इसे बाएं नोड या राइट नोड के रूप में जोड़ने का निर्णय लेती है। अंत में, ट्री को प्रिंट करने के लिए PrintTree विधि का उपयोग किया जाता है।

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data

    def insert(self, data):
# Compare the new value with the parent node
        if self.data:
            if data < self.data:
                if self.left is None:
                    self.left = Node(data)
                else:
                    self.left.insert(data)
            elif data > self.data:
                if self.right is None:
                    self.right = Node(data)
                else:
                    self.right.insert(data)
        else:
            self.data = data

# Print the tree
    def PrintTree(self):
        if self.left:
            self.left.PrintTree()
        print( self.data),
        if self.right:
            self.right.PrintTree()

# Use the insert method to add nodes
root = Node(12)
root.insert(6)
root.insert(14)
root.insert(3)

root.PrintTree()

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

3 6 12 14

एक पेड़ पर चढ़ना

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