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

C++ में बाइनरी ट्री में सिक्के वितरित करें

मान लीजिए कि हमारे पास एन नोड्स के साथ एक बाइनरी ट्री की जड़ है, यहां पेड़ के प्रत्येक नोड में सिक्कों की संख्या है, और कुल एन सिक्के हैं। एक चाल में, हम दो आसन्न नोड्स चुन सकते हैं और केवल एक सिक्के को एक नोड से दूसरे नोड में स्थानांतरित कर सकते हैं। (चाल माता-पिता से बाल नोड तक, या बच्चे से माता-पिता नोड तक हो सकता है।) हमें प्रत्येक नोड में एक सिक्का बनाने के लिए आवश्यक चालों की संख्या ज्ञात करनी होगी।

तो अगर पेड़ जैसा है -

फिर आउटपुट 3 होगा। बाएं बच्चे से, 2 सिक्कों को रूट पर भेजें (प्रत्येक सिक्के के लिए एक चाल, इसलिए कुल 2 चालें), फिर एक सिक्के को रूट से दाएं बच्चे तक ले जाएं, इसलिए कुल मिलाकर 3 चालें हैं।

इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -

  • हल () नामक एक पुनरावर्ती विधि को परिभाषित करें, यह रूट नामक एक नोड लेगा

  • यदि रूट शून्य है, तो 0 पर लौटें

  • l :=हल करें (रूट के बाएँ)

  • r :=हल करें (मूल का दाहिना भाग)

  • उत्तर :=|l| + |r|

  • रिटर्न l + r + रूट का मान – 1

  • मुख्य भाग में, उत्तर सेट करें:=0, कॉल हल करें (रूट), फिर उत्तर वापस करें

उदाहरण

#include <bits/stdc++.h>
using namespace std;
class TreeNode{
   public:
   int val;
   TreeNode *left, *right;
   TreeNode(int data){
      val = data;
      left = NULL;
      right = NULL;
   }
};
void insert(TreeNode **root, int val){
   queue<TreeNode*> q;
   q.push(*root);
   while(q.size()){
      TreeNode *temp = q.front();
      q.pop();
      if(!temp->left){
         if(val != NULL)
            temp->left = new TreeNode(val);
         else
            temp->left = new TreeNode(0);
         return;
      }else{
         q.push(temp->left);
      }
      if(!temp->right){
         if(val != NULL)
            temp->right = new TreeNode(val);
         else
            temp->right = new TreeNode(0);
         return;
      }else{
         q.push(temp->right);
      }
   }
}
TreeNode *make_tree(vector<int> v){
   TreeNode *root = new TreeNode(v[0]);
   for(int i = 1; i<v.size(); i++){
      insert(&root, v[i]);
   }
   return root;
}
class Solution {
   public:
   int ans;
   int solve(TreeNode* root){
      if(!root)return 0;
      int l = solve(root->left);
      int r = solve(root->right);
      ans += abs(l) + abs(r);
      return l + r + root->val - 1;
   }
   int distributeCoins(TreeNode* root) {
      ans = 0;
      solve(root);
      return ans;
   }
};
main(){
   vector<int> v = {0,3,0};
   TreeNode *root = make_tree(v);
   Solution ob;
   cout << (ob.distributeCoins(root));
}   

इनपुट

[0,3,0]

आउटपुट

3

  1. C++ में बाइनरी ट्री प्रूनिंग

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

  1. C++ में बाइनरी ट्री को लिंक्ड लिस्ट में समतल करें

    मान लीजिए हमारे पास एक बाइनरी ट्री है; हमें इसे जगह में लिंक्ड सूची में समतल करना होगा। तो अगर पेड़ जैसा है - आउटपुट ट्री होगा - इसे हल करने के लिए, हम इन चरणों का पालन करेंगे - सेवा पिछला:=शून्य एक पुनरावर्ती फ़ंक्शन हल () को परिभाषित करें, जो इनपुट के रूप में रूट लेगा। यदि रूट

  1. C++ में बाइनरी ट्री लेवल ऑर्डर ट्रैवर्सल

    मान लीजिए कि हमारे पास एक बाइनरी ट्री है। हमें लेवल ऑर्डर ट्रैवर्सल स्कीम का उपयोग करके इस पेड़ को पार करना होगा। तो अगर पेड़ ऐसा है ट्रैवर्सल अनुक्रम इस प्रकार होगा - [10, 5, 16, 8, 15, 20, 23] इसे हल करने के लिए, हम इन चरणों का पालन करेंगे - नोड्स को स्टोर करने के लिए क्यू को परिभाषित करें क्