डेटा संरचना में बाइनरी ट्री (उदाहरण)
बाइनरी ट्री क्या है?
बाइनरी शब्द का मतलब दो होता है। ट्री डेटा स्ट्रक्चर में "बाइनरी ट्री" का मतलब एक ऐसा पेड़ होता है, जहाँ प्रत्येक नोड में अधिकतम दो चाइल्ड नोड (बाएं और दाएं नोड) हो सकते हैं। यह एक सरल बाइनरी ट्री है।
हालाँकि, एक और बाइनरी ट्री है जिसका सबसे अधिक बार उपयोग किया जाता है और इसके कई उपयोग मामले हैं। इसे बाइनरी सर्च ट्री (BST) कहा जाता है। यह ट्री सर्च एल्गोरिदम को बहुत तेज़ बना सकता है, ठीक लॉग (n) समय जटिलता। डेटा संरचना में, n का मतलब बाइनरी ट्री में नोड्स की संख्या है।
बाइनरी ट्री और बाइनरी सर्च ट्री के बीच क्या अंतर हैं?
BST और नियमित बाइनरी ट्री के बीच अंतर यह है कि BST में बाएं नोड का मान रूट नोड से छोटा होता है, और दाएं नोड का मान रूट नोड से बड़ा होता है। इसलिए, बाएं उपवृक्ष में हमेशा रूट से छोटा मान होगा, और दाएं उपवृक्ष में हमेशा रूट से बड़ा मान होगा।
बाइनरी सर्च ट्री का उदाहरण
आइये बाइनरी सर्च ट्री की अवधारणाओं को प्रदर्शित करने के लिए निम्नलिखित उदाहरण देखें।
यहाँ आप देख सकते हैं कि सभी नोड्स दिए गए अनुशासन का पालन करते हैं। बाइनरी सर्च ट्री में नोड्स की अधिकतम संख्या के लिए एक सूत्र है। यदि हम उपरोक्त ट्री को देखें, तो हम देख सकते हैं कि सभी लीफ नोड्स को छोड़कर प्रत्येक नोड में दो बच्चे हैं। और दिए गए बाइनरी ट्री की ऊँचाई (h) 4 है। सूत्र है 2h - 1. तो, यह 15 देता है.
ऊपर दी गई छवि एक पूर्ण बाइनरी ट्री या संतुलित बाइनरी ट्री नहीं है, इसे पूर्ण बाइनरी ट्री या संतुलित बाइनरी ट्री कहा जाता है। AVL (बाइनरी ट्री का एक अन्य प्रकार) नामक एक और डेटा संरचना है जो बाइनरी ट्री की ऊंचाई को अनुकूलित करती है और चित्र 3 की तरह BST के लिए तेज़ी से खोज करती है।
ऊपर दिए गए बाइनरी ट्री के इन-ऑर्डर ट्रैवर्सल की गणना करने का प्रयास करें। आप पाएंगे कि यह एक गैर-घटती क्रमबद्ध सरणी देगा, और ट्रैवर्सल एल्गोरिदम बाइनरी ट्री के समान होगा।
बाइनरी ट्री के प्रकार
बाइनरी ट्री के कुछ महत्वपूर्ण प्रकार यहां दिए गए हैं:
- पूर्ण बाइनरी ट्री: इस बाइनरी ट्री में प्रत्येक नोड में 0 या 2 चाइल्ड नोड हो सकते हैं। इस प्रकार के बाइनरी ट्री में केवल एक चाइल्ड नोड की अनुमति नहीं है। इसलिए, लीफ नोड को छोड़कर, सभी नोड्स में 2 चाइल्ड नोड होंगे।
- पूर्ण बाइनरी ट्री: प्रत्येक नोड में 0 या 2 नोड हो सकते हैं। यह पूर्ण बाइनरी ट्री की तरह लगता है, लेकिन सभी लीफ तत्व बाएं उपवृक्ष की ओर झुके होते हैं, जबकि पूर्ण बाइनरी ट्री में नोड दाएं या बाएं उपवृक्ष में हो सकता है।
- परफेक्ट बाइनरी ट्री: सभी नोड्स में 0 या 2 नोड होने चाहिए, और सभी लीफ नोड्स एक ही स्तर या ऊंचाई पर होने चाहिए। पूर्ण बाइनरी ट्री संरचना का उपरोक्त उदाहरण एक परफेक्ट बाइनरी ट्री नहीं है क्योंकि नोड 6 और नोड 1,2,3 एक ही ऊंचाई पर नहीं हैं। लेकिन पूर्ण बाइनरी ट्री का उदाहरण एक परफेक्ट बाइनरी ट्री है।
- पतित बाइनरी वृक्ष: प्रत्येक नोड में केवल एक ही संतान हो सकती है। सभी ऑपरेशन जैसे खोजना, सम्मिलित करना और हटाना O(N) समय लेते हैं।
- संतुलित बाइनरी ट्री: यहाँ इस बाइनरी ट्री में, बाएं और दाएं सबट्री की ऊंचाई का अंतर अधिकतम 1 है। इसलिए, नोड जोड़ते या हटाते समय, हमें ट्री की ऊंचाई को फिर से संतुलित करने की आवश्यकता होती है। इस प्रकार के स्व-संतुलित बाइनरी ट्री को कहा जाता है एवीएल पेड़.
बीएसटी के तीन बुनियादी ऑपरेशन हैं। नीचे उन पर विस्तार से चर्चा की गई है।
सी और सी में बाइनरी ट्री का कार्यान्वयन C++
#include <iostream> #include <bits/stdc++.h> using namespace std; struct Node { int value; struct Node *left, *right; } struct Node *getEmptynode(int val) { struct Node *tempNode = (struct Node *)malloc(sizeof(struct Node)); tempNode->value = val; tempNode->left = NULL; tempNode->right = NULL; return tempNode; } struct Node *successor(struct Node *node) { struct Node *present = node; // going to the left most node while (present != NULL && present->left != NULL) { present = present->left; } return present; } struct Node *insert(struct Node *node, int value) { if (node == NULL) { return getEmptynode(value); } if (value < node->value) { node->left = insert(node->left, value); } else { node->right = insert(node->right, value); } return node; } int searchInBST(struct Node *node, int value) { struct Node *current = node; while (current->value != value) { if (current->value > value) { current = current->left; } else { current = current->right; } if (current == NULL) { return 0; } } return 1; } void inorder(struct Node *root) { if (root != NULL) { inorder(root->left); cout << root->value << " "; inorder(root->right); } } struct Node *deleteNode(struct Node *node, int value) { if (node == NULL) { return node; } if (value < node->value) { node->left = deleteNode(node->left, value); } else if (value > node->value) { node->right = deleteNode(node->right, value); } else { if (node->left == NULL) { struct Node *temp = node->right; free(node); return temp; } else if (node->right == NULL) { struct Node *temp = node->left; free(node); return temp; } struct Node *temp = successor(node->right); node->value = temp->value; node->right = deleteNode(node->right, temp->value); } return node; } int main() { struct Node *root = NULL; root = insert(root, 8); root = insert(root, 4); root = insert(root, 12); root = insert(root, 2); root = insert(root, 6); root = insert(root, 10); root = insert(root, 14); root = insert(root, 1); root = insert(root, 3); root = insert(root, 5); root = insert(root, 7); root = insert(root, 9); root = insert(root, 11); root = insert(root, 13); root = insert(root, 15); cout << "InOrder Traversal after inserting all nodes: " << endl; inorder(root); root = insert(root, -10); cout << "\nInOrder Traversal after inserting -10 : " << endl; inorder(root); cout << "\nSearching -5 in the BST: " << searchInBST(root, -5) << endl; cout << "Searching -10 in the BST: " << searchInBST(root, -10) << endl; root = deleteNode(root,8); cout<<"After deleting node 8, inorder traversal: "<<endl; inorder(root); root = deleteNode(root,-10); cout<<"\nAfter deleting node -10, inorder traversal: "<<endl; inorder(root); }
आउटपुट:
InOrder Traversal after inserting all nodes: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 InOrder Traversal after inserting -10 : 10 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Searching -5 in the BST: 0 Searching -10 in the BST: 1 After deleting node 8, inorder traversal: -10 1 2 3 4 5 6 7 9 10 11 12 13 14 15 After deleting node -10, inorder traversal: 1 2 3 4 5 6 7 9 10 11 12 13 14 15
बाइनरी ट्री का कार्यान्वयन Python
class Node: def __init__(self,value): self.left = None self.right = None self.value = value def insert(root,value): if root == None: return Node(value) if value< root.value: root.left = insert(root.left,value) else: root.right = insert(root.right,value) return root def searchInBST(root,value): current = root while current.value != value: if current.value > value: current = current.left else: current = current.right if current == None: return "Not found" return "Found" def inorder(root): if root != None: inorder(root.left) print(root.value,end=" ") inorder(root.right) def successor(root): present = root while present != None and present.left != None: present = present.left return present def deleteNode(root,value): if root == None: return root if value < root.value: root.left = deleteNode(root.left, value) elif value>root.value: root.right = deleteNode(root.right, value) else: if root.left == None: temp = root.right root = None return temp elif root.right == None: temp = root.left root = None return temp temp = successor(root.right) root.value = temp.value root.right = deleteNode(root.right, temp.value) return root root = Node(8) root = insert(root, 4) root = insert(root, 12) root = insert(root, 2) root = insert(root, 6) root = insert(root, 10) root = insert(root, 14) root = insert(root, 1) root = insert(root, 3) root = insert(root, 5) root = insert(root, 7) root = insert(root, 9) root = insert(root, 11) root = insert(root, 13) root = insert(root, 15) print("InOrder Traversal after inserting all nodes: ") inorder(root) root = insert(root, -10) print("\nInOrder Traversal after inserting -10 : ") inorder(root) print("\nSearching -5 in the BST: ",searchInBST(root, -5)) print("Searching -5 in the BST: ",searchInBST(root, -10)) root = deleteNode(root,8) print("After deleting node 8, inorder traversal:") inorder(root) root = deleteNode(root,-10) print("\nAfter deleting node -10, inorder traversal:") inorder(root)
आउटपुट:
InOrder Traversal after inserting all nodes 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 InOrder Traversal after inserting -10 : -10 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Searching -5 in the BST: Not found Searching -5 in the BST: Found After deleting node 8, inorder traversal: -10 1 2 3 4 5 6 7 9 10 11 12 13 14 15 After deleting node -10, inorder traversal: 1 2 3 4 5 6 7 9 10 11 12 13 14 15
बाइनरी ट्री का अनुप्रयोग
बाइनरी ट्री के कुछ सामान्य अनुप्रयोग इस प्रकार हैं:
- नोड डेटा को क्रमबद्ध क्रम में व्यवस्थित करना
- प्रोग्रामिंग भाषा लाइब्रेरी में मानचित्र और सेट नोड ऑब्जेक्ट में उपयोग किया जाता है।
- डेटा संरचनाओं में तत्वों की खोज करना
» हमारे अगले ट्यूटोरियल के बारे में जानें संयोजन एल्गोरिथ्म