Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> C++

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

बाइनरी सर्च ट्री (BST) एक विशेष प्रकार का वृक्ष है जो निम्नलिखित नियमों का पालन करता है -

  • लेफ्ट चाइल्ड नोड का मान हमेशा पैरेंट नोट से कम होता है

  • राइट चाइल्ड नोड का मान पैरेंट नोड से अधिक होता है।

  • सभी नोड्स व्यक्तिगत रूप से एक बाइनरी सर्च ट्री बनाते हैं।

बाइनरी सर्च ट्री (BST) का उदाहरण -

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

खोज, न्यूनतम और अधिकतम खोजें जैसे कार्यों की जटिलता को कम करने के लिए बाइनरी सर्च ट्री बनाया जाता है।

ऑपरेशन बाइनरी सर्च ट्री (BST) हटाएं

डिलीट ऑपरेशन पेड़ से निर्दिष्ट नोड को गिरा रहा है। नोड्स को हटाने के मामले में, तीन संभावनाएं हैं -

  • ट्री से लीफ नोड को हटाना:सबसे सरल विलोपन बाइनरी सर्च ट्री से लीफ नोड को हटाना है। लीफ नोड को हटाने के लिए केवल पत्ती प्रभावित होती है। उदाहरण,

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

लीफ नोड को हटाने से 7 देता है,

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

  • एक चाइल्ड नोड के साथ नोड को हटाना:इस विलोपन के लिए, आपको चाइल्ड नोड को हटाए जाने वाले नोड से बदलना होगा और फिर इसे हटाना होगा। उदाहरण,

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

BST से 2 हटाना

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

  • दो चाइल्ड नोड्स के साथ नोड को हटाना:यहां हटाए जाने वाले नोड में दो चाइल्ड नोड होते हैं। तो, हम पेड़ के क्रम रूप में उपयोग करेंगे, यहां हम तत्व को हटा देंगे और इसके स्थान के लिए इसके पड़ोसी पड़ोसी का चयन करेंगे और बाकी को फिर से बनाएंगे। उदाहरण,

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

5 को BST से हटाने पर निम्न ट्री वापस आ जाएगा।

बाइनरी सर्च ट्री - सी ++ में ऑपरेशन हटाएं

उदाहरण

#include<stdio.h>
#include<stdlib.h>
struct node{
   int key;
   struct node *left, *right;
};
struct node *newNode(int item){
   struct node *temp = (struct node *)malloc(sizeof(struct node));
   temp->key = item;
   temp->left = temp->right = NULL;
   return temp;
}
void inordertraversal(struct node *root){
   if (root != NULL){
      inordertraversal(root->left);
      printf("%d ", root->key);
      inordertraversal(root->right);
   }
}
struct node* insert(struct node* node, int key){
   if (node == NULL) return newNode(key);
      if (key < node->key)
         node->left = insert(node->left, key);
      else
         node->right = insert(node->right, key);
   return node;
}
struct node * minValueNode(struct node* node){
   struct node* current = node;
   while (current && current->left != NULL)
      current = current->left;
   return current;
}
struct node* deleteNode(struct node* root, int key){
   if (root == NULL) return root;
      if (key < root->key)
         root->left = deleteNode(root->left, key);
      else if (key > root->key)
         root->right = deleteNode(root->right, key);
   else{
      if (root->left == NULL){
         struct node *temp = root->right;
         free(root);
         return temp;
      }
      else if (root->right == NULL){
         struct node *temp = root->left;
         free(root);
         return temp;
      }
      struct node* temp = minValueNode(root->right);
      root->key = temp->key;
      root->right = deleteNode(root->right, temp->key);
   }
   return root;
}
int main(){
   struct node *root = NULL;
   root = insert(root, 50);
   root = insert(root, 30);
   root = insert(root, 20);
   root = insert(root, 40);
   root = insert(root, 70);
   root = insert(root, 60);
   root = insert(root, 80);
   printf("Inorder traversal of the given tree \n");
   inordertraversal(root);
   printf("\nDelete 20\n");
   root = deleteNode(root, 20);
   printf("Inorder traversal of the modified tree \n");
   inordertraversal(root);
   printf("\nDelete 30\n");
   root = deleteNode(root, 30);
   printf("Inorder traversal of the modified tree \n");
   inordertraversal(root);
   printf("\nDelete 50\n");
   root = deleteNode(root, 50);
   printf("Inorder traversal of the modified tree \n");
   inordertraversal(root);
   return 0;
}

आउटपुट

Inorder traversal of the given tree
20 30 40 50 60 70 80
Delete 20
Inorder traversal of the modified tree
30 40 50 60 70 80
Delete 30
Inorder traversal of the modified tree
40 50 60 70 80
Delete 50
Inorder traversal of the modified tree
40 60 70 80

  1. C++ में बाइनरी सर्च ट्री इटरेटर

    मान लीजिए हम बाइनरी ट्री के लिए एक इटरेटर बनाना चाहते हैं। दो तरीके होंगे। अगला () विधि अगले तत्व को वापस करने के लिए है, और hasNext () विधि बूलियन मान वापस करने के लिए है, जो इंगित करेगा कि अगला तत्व मौजूद है या नहीं। तो अगर पेड़ जैसा है - और फ़ंक्शन कॉल का क्रम [अगला (), अगला (), है नेक्स्ट (),

  1. C++ में बाइनरी ट्री टू बाइनरी सर्च ट्री रूपांतरण

    एक बाइनरी ट्री एक विशेष प्रकार का पेड़ है जिसमें पेड़ के प्रत्येक नोड में अधिकतम दो बच्चे नोड हो सकते हैं। इन चाइल्ड नोड्स को राइट चाइल्ड और लेफ्ट चाइल्ड के रूप में जाना जाता है। एक साधारण बाइनरी ट्री है - बाइनरी सर्च ट्री (BST) एक विशेष प्रकार का वृक्ष है जो निम्नलिखित नियमों का पालन करता है -

  1. C++ में बाइनरी सर्च ट्री में न्यूनतम मान वाला नोड खोजें

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