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

एक बीएसटी को एक बाइनरी ट्री में कनवर्ट करें जैसे कि सी ++ में प्रत्येक कुंजी में सभी बड़ी चाबियों का योग जोड़ा जाता है

इस ट्यूटोरियल में, हम एक BST को बाइनरी ट्री में बदलने के लिए एक प्रोग्राम पर चर्चा करेंगे जैसे कि सभी बड़ी कुंजियों का योग प्रत्येक कुंजी में जोड़ा जाता है।

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

उदाहरण

#include <bits/stdc++.h>
using namespace std;
//node structure of BST
struct node{
   int key;
   struct node* left;
   struct node* right;
};
//creating new node with no child
struct node* newNode(int key){
   struct node* node = (struct node*)malloc(sizeof(struct node));
   node->key = key;
   node->left = NULL;
   node->right = NULL;
   return (node);
}
//traversing BST in reverse inorder and adding sum
void reverse_BST(struct node *root, int *sum_ptr){
   if (root == NULL)
      return;
   reverse_BST(root->right, sum_ptr);
   //adding elements along the way
   *sum_ptr = *sum_ptr + root->key;
   root->key = *sum_ptr;
   reverse_BST(root->left, sum_ptr);
}
//Using sum and updating the values
void change_greater(struct node *root){
   int sum = 0;
   reverse_BST(root, &sum);
}
//printing inorder traversal
void printInorder(struct node* node){
   if (node == NULL)
      return;
   printInorder(node->left);
   cout << node->key << " " ;
   printInorder(node->right);
}
int main(){
   node *root = newNode(5);
   root->left = newNode(2);
   root->right = newNode(13);
   cout << "Given Tree :" << endl;
   printInorder(root);
   change_greater(root);
   cout << endl;
   cout << "Modified Tree :" << endl;
   printInorder(root);
   return 0;
}

आउटपुट

Given Tree :
2 5 13
Modified Tree :
20 18 13

  1. C++ में बाइनरी ट्री में अधिकतम सर्पिल योग

    इस समस्या में हमें एक बाइनरी ट्री दिया जाता है। हमारा काम एक प्रोग्राम बनाना है जो C++ में एक बाइनरी ट्री में अधिकतम सर्पिल योग प्राप्त करेगा। सर्पिल योग बाइनरी ट्री का, बाइनरी ट्री के स्पाइरल ट्रैवर्सल में पाए जाने वाले नोड्स का योग होता है। एक पेड़ के सर्पिल ट्रैवर्सल में, नोड्स को रूट से लीफ न

  1. C++ में दिए गए परफेक्ट बाइनरी ट्री के सभी नोड्स का योग ज्ञात करें

    मान लीजिए कि हमारे पास एक सकारात्मक पूर्णांक L है, जो एक पूर्ण बाइनरी ट्री में स्तरों की संख्या का प्रतिनिधित्व करता है। इस परफेक्ट बाइनरी ट्री में लीफ नोड्स की संख्या 1 से n तक होती है। जहां n लीफ नोड्स की संख्या है। पैरेंट नोड बच्चों का योग है। हमारा काम इस परफेक्ट बाइनरी ट्री के सभी नोड्स के योग

  1. C++ में दिए गए BST में प्रत्येक नोड में सभी बड़े मान जोड़ें?

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