কম্পিউটার

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;
         break;
      }
   }
}
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, 36);
}

আউটপুট

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

15 21

উপসংহার

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


  1. সি++ এ রুটের ডেটার সমতুল্য সমষ্টি সহ একটি পাতার পথের রুটে একটি জোড়া আছে কিনা তা খুঁজুন

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

  3. C++ এ প্রদত্ত GCD এবং LCM সহ যেকোনো জোড়া খুঁজুন

  4. জাভাতে একটি সুষম BST-এ প্রদত্ত যোগফলের সাথে একটি জোড়া খুঁজুন