কম্পিউটার

C++ এ একটি BST-তে প্রদত্ত যোগফল সহ সমস্ত জোড়া খুঁজুন


এই টিউটোরিয়ালে, আমরা একটি প্রোগ্রাম লিখতে যাচ্ছি যেটি সমস্ত জোড়া খুঁজে বের করে যার যোগফল বাইনারি সার্চ ট্রিতে প্রদত্ত সংখ্যার সমান।

আমরা জোড়া খুঁজে পেতে দুটি ভিন্ন তালিকায় গাছের মূল্য সংরক্ষণ করতে যাচ্ছি। আসুন সমস্যা সমাধানের পদক্ষেপগুলি দেখি৷

  • একটি বাইনারি গাছের জন্য একটি স্ট্রাকট নোড তৈরি করুন।

  • বাইনারি সার্চ ট্রিতে একটি নতুন নোড সন্নিবেশ করার জন্য একটি ফাংশন লিখুন।

    • মনে রাখবেন, বাইনারি সার্চ ট্রিতে মূলের চেয়ে কম উপাদানগুলি ছোট এবং ডানগুলি বড়৷

  • গাছের বাম এবং ডান নোডগুলি সংরক্ষণ করতে দুটি খালি তালিকা শুরু করুন৷

  • বাইনারি সার্চ ট্রিতে পুনরাবৃত্তি করুন যতক্ষণ না বাম বা ডান নোডগুলি NULL হয় বা উভয় তালিকাই খালি না হয়৷

    • বাম নোড তালিকায় সমস্ত উপাদান সংরক্ষণ করার জন্য একটি লুপ লিখুন।

    • সঠিক নোড তালিকায় সমস্ত উপাদান সংরক্ষণ করার জন্য একটি লুপ লিখুন।

    • প্রতিটি তালিকা থেকে শেষ নোডগুলি পান৷

    • দুটি মান পরীক্ষা করুন।

      • যদি বাম দিকের নোডের মান ডান পাশের নোডের মানের থেকে বেশি বা সমান হয়, তাহলে লুপটি ভেঙে দিন।

      • যদি দুটি মানের যোগফল প্রদত্ত সংখ্যার সমান হয়, তাহলে তালিকাগুলি থেকে মুদ্রণ করুন এবং মুছুন

      • যদি দুটি মানের যোগফল প্রদত্ত সংখ্যার থেকে কম হয়, তাহলে বাম তালিকা থেকে শেষ নোডটি মুছে দিন এবং নোডের ডানদিকে যান৷

      • যদি দুটি মানের যোগফল প্রদত্ত সংখ্যার চেয়ে বড় হয়, তাহলে ডান তালিকা থেকে শেষ নোডটি মুছে দিন এবং নোডের বাম দিকে যান৷

উদাহরণ

আসুন কোডটি দেখি।

#include<bits/stdc++.h>
using namespace std;
struct Node{
   int data;
   Node *left, *right, *root;
   Node(int data) {
      this->data = data;
      left = NULL;
      right = NULL;
      root = NULL;
   }
};
Node* insertNewNode(Node *root, int data){
   if (root == NULL) {
      root = new Node(data);
      return root;
   }
   if (root->data < data) {
      root->right = insertNewNode(root->right, data);
   }
   else if (root->data > data) {
      root->left = insertNewNode(root->left, data);
   }
   return root;
}
void findThePairs(Node *node, int target) {
   vector<Node*> left_side_nodes;
   vector<Node*> right_side_nodes;
   Node *current_left = node;
   Node *current_right = node;
   while (current_left != NULL || current_right != NULL || (left_side_nodes.size() > 0 && right_side_nodes.size() > 0)) {
      while (current_left != NULL) {
         left_side_nodes.push_back(current_left);
         current_left = current_left->left;
      }
      while (current_right != NULL) {
         right_side_nodes.push_back(current_right);
         current_right = current_right->right;
      }
      Node *left_side_node = left_side_nodes[left_side_nodes.size() - 1];
      Node *right_side_node = right_side_nodes[right_side_nodes.size() - 1];
      int left_side_value = left_side_node->data;
      int right_side_value = right_side_node->data;
      if (left_side_value >= right_side_value) {
         break;
      }
      if (left_side_value + right_side_value < target) {
         left_side_nodes.pop_back();
         current_left = left_side_node->right;
      }
      else if (left_side_value + right_side_value > target) {
         right_side_nodes.pop_back();
         current_right = right_side_node->left;
      }
      else {
         cout << left_side_node->data << " " << right_side_node->data << endl;
         right_side_nodes.pop_back();
         left_side_nodes.pop_back();
         current_left = left_side_node->right;
         current_right = right_side_node->left;
      }
   }
}
int main() {
   Node *root = NULL;
   root = insertNewNode(root, 25);
   root = insertNewNode(root, 20);
   root = insertNewNode(root, 30);
   root = insertNewNode(root, 15);
   root = insertNewNode(root, 21);
   root = insertNewNode(root, 19);
   root = insertNewNode(root, 31);
   findThePairs(root, 50);
}t, *root;
   Node(int data) {
      this->data = data;
      left = NULL;
      right = NULL;
      root = NULL;
   }  
};
Node* insertNewNode(Node *root, int data){
   if (root == NULL) {
      root = new Node(data);
      return root;
   }
   if (root->data < data) {
      root->right = insertNewNode(root->right, data);
   }
   else if (root->data > data) {
      root->left = insertNewNode(root->left, data);
   }
   return root;
}
void findThePairs(Node *node, int tar) {
   vector<Node*> left_side_nodes;
   vector<Node*> right_side_nodes;
   Node *current_left = node;
   Node *current_right = node;
   while (current_left != NULL || current_right != NULL || (left_side_nodes.size() > 0 && right_side_nodes.size() > 0)) {
      while (current_left != NULL) {
         left_side_nodes.push_back(current_left);
         current_left = current_left->left;
      }
      while (current_right != NULL) {
         right_side_nodes.push_back(current_right);
         current_right = current_right->right;
      }
      Node *left_side_node = left_side_nodes[left_side_nodes.size() - 1];
      Node *right_side_node = right_side_nodes[right_side_nodes.size() - 1];
      int left_side_value = left_side_node->data;
      int right_side_value = right_side_node->data;
      if (left_side_value >= right_side_value) {
         break;
      }
      if (left_side_value + right_side_value < tar) {
         left_side_nodes.pop_back();
         current_left = left_side_node->right;
      }
      else if (left_side_value + right_side_value > tar) {
         right_side_nodes.pop_back();
         current_right = right_side_node->left;
      }
      else {
         cout << left_side_node->data << " " << right_side_node->data << endl;
         right_side_nodes.pop_back();
         left_side_nodes.pop_back();
         current_left = left_side_node->right;
         current_right = right_side_node->left;
      }
   }
}
int main() {
   Node *root = NULL;
   root = insertNewNode(root, 25);
   root = insertNewNode(root, 20);
   root = insertNewNode(root, 30);
   root = insertNewNode(root, 15);
   root = insertNewNode(root, 21);
   root = insertNewNode(root, 19);
   root = insertNewNode(root, 31);
   findThePairs(root, 50);
}

আউটপুট

আপনি যদি উপরের কোডটি চালান, তাহলে আপনি নিম্নলিখিত ফলাফল পাবেন।

19 31
20 30

উপসংহার

টিউটোরিয়ালে আপনার কোন প্রশ্ন থাকলে মন্তব্য বিভাগে উল্লেখ করুন।


  1. C++ এ একটি প্রদত্ত বাইনারি ট্রিতে সমস্ত সঠিক পাতার সমষ্টি খুঁজুন

  2. C++ এ একটি প্রদত্ত বাইনারি ট্রিতে সমস্ত বাম পাতার সমষ্টি খুঁজুন

  3. C++ এ একটি সুষম BST-এ প্রদত্ত যোগফল সহ একটি জোড়া খুঁজুন

  4. C++ এ প্রদত্ত নিখুঁত বাইনারি গাছের সমস্ত নোডের সমষ্টি খুঁজুন