अजगर - बाइनरी ट्री
ट्री किनारों द्वारा जुड़े नोड्स का प्रतिनिधित्व करता है। यह एक गैर-रेखीय डेटा संरचना है। इसके निम्नलिखित गुण हैं।
- एक नोड को रूट नोड के रूप में चिह्नित किया गया है।
- जड़ के अलावा हर नोड एक मूल नोड के साथ जुड़ा हुआ है।
- प्रत्येक नोड में 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
एक पेड़ पर चढ़ना
प्रत्येक नोड पर जाने के लिए एक अनुक्रम पर निर्णय लेने से पेड़ का पता लगाया जा सकता है। जैसा कि हम स्पष्ट रूप से देख सकते हैं कि हम एक नोड पर शुरू कर सकते हैं फिर बाएं उप-पेड़ पर जाएं और अगले उप-पेड़ के बगल में जाएं। या हम पहले दाहिने उप-पेड़ और अगले उप-पेड़ पर भी जा सकते हैं। तदनुसार, इन पेड़ ट्रैवर्सल विधियों के अलग-अलग नाम हैं। हम यहां पेड़ ट्रैवर्सल एल्गोरिदम को लागू करने वाले अध्याय में विस्तार से उनका अध्ययन करते हैं। ट्री ट्रैवर्सल एल्गोरिदम