কম্পিউটার

C++ পাথের দৈর্ঘ্য সর্বাধিক সংখ্যক বাঁক রয়েছে


একটি সমস্যা সমাধানের জন্য যেখানে আমাদের একটি বাইনারি গাছ দেওয়া হয়েছে। এখন আমাদের সর্বাধিক সংখ্যক বাঁক থাকার পথটি খুঁজে বের করতে হবে। যেমন, একটি বাঁক বিবেচনা করা হয় যখন পথের দিক বাম থেকে ডানে বা বিপরীত দিকে পরিবর্তিত হয়, উদাহরণস্বরূপ

ইনপুট -

C++ পাথের দৈর্ঘ্য সর্বাধিক সংখ্যক বাঁক রয়েছে

আউটপুট -

6

এখন এই পদ্ধতিতে, আমরা গাছের মধ্য দিয়ে অতিক্রম করব এবং পূর্ববর্তী গতিবিধির উপর নজর রাখব। যদি দিক পরিবর্তন হয়, আমরা কেবল আমাদের বাঁকের সংখ্যা আপডেট করি এবং তারপরে আমরা সর্বাধিক খুঁজে পাই।

সমাধান খোঁজার পদ্ধতি

এই পদ্ধতিতে, আমরা সমস্ত পথ অতিক্রম করব, এবং আমরা আমাদের উত্তর আপডেট করার সর্বাধিক সংখ্যক বাঁক খুঁজে পাব।

উদাহরণ

#include <bits/stdc++.h>
using namespace std;
struct Node { // structure of our node
    int key;
    struct Node* left;
    struct Node* right;
};
struct Node* newNode(int key){ // initializing our node
    struct Node* node = new Node();
    node->left = NULL;
    node->right = NULL;
    node->key = key;
    return node;
}
void maximumBends(struct Node* node,char direction, int bends,
                    int* maxBends, int soFar,int* len){
    if (node == NULL) // if null is reached
       return;
    if (node->left == NULL && node->right == NULL) { // if we reach the leaf node then
                                                   //we check if we have to update our answer or not
        if (bends > *maxBends) {
            *maxBends = bends;
            *len = soFar;
        }
    }
    else {
        if (direction == 'l') { // current direction is left
            maximumBends(node->left, direction,bends, maxBends,soFar + 1, len);
            maximumBends(node->right, 'r',bends + 1, maxBends,soFar + 1, len); // if we change direction so bend also increases
        }
        else {
            maximumBends(node->right, direction,bends, maxBends,soFar + 1, len);
            maximumBends(node->left, 'l',bends + 1, maxBends,soFar + 1, len); // same as when direction was left
        }
    }
}
int main(){
    struct Node* root = newNode(10);
    root->left = newNode(8);
    root->right = newNode(2);
    root->left->left = newNode(3);
    root->left->right = newNode(5);
    root->right->left = newNode(2);
    root->right->left->right = newNode(1);
    root->right->left->right->left = newNode(9);
    int len = 0, bends = 0, maxBends = -1;
    if(!root) // if tree is empty
       cout << "0\n";
    else{
        if (root->left) // if left subtree exists
            maximumBends(root->left, 'l',bends, &maxBends, 1, &len);
        if (root->right) // if right subtree exists
            maximumBends(root->right, 'r', bends,&maxBends, 1, &len);
        cout << len << "\n";
    }
    return 0;
}

আউটপুট

4

উপরের কোডের ব্যাখ্যা

উপরোক্ত পদ্ধতিতে, আমরা কেবলমাত্র সমস্ত পথ অতিক্রম করছি এবং এখন পর্যন্ত পাওয়া বাঁকগুলি গণনা করছি যখন আমরা পথের শেষ প্রান্তে পৌঁছেছি। অর্থাৎ লিফ নোড, আমরা পরীক্ষা করি যে এখান পর্যন্ত বাঁকগুলি আগের সর্বাধিকের চেয়ে বেশি এখন যদি শর্তটি সত্য, তাই আমরা আমাদের সর্বাধিক বাঁক এবং এই নতুন দৈর্ঘ্যের পথের দৈর্ঘ্য আপডেট করি, এবং এভাবেই আমাদের প্রোগ্রাম এগিয়ে যায়।

উপসংহার

এই টিউটোরিয়ালে, আমরা সর্বাধিক সংখ্যক বাঁক বিশিষ্ট পথের দৈর্ঘ্য খুঁজে বের করার জন্য একটি সমস্যার সমাধান করি। আমরা এই সমস্যার জন্য C++ প্রোগ্রাম এবং সম্পূর্ণ পদ্ধতি (স্বাভাবিক) শিখেছি যার মাধ্যমে আমরা এই সমস্যার সমাধান করেছি। আমরা অন্যান্য ভাষা যেমন সি, জাভা, পাইথন এবং অন্যান্য ভাষায় একই প্রোগ্রাম লিখতে পারি। আমরা আশা করি আপনার এই টিউটোরিয়ালটি সহায়ক হবে৷


  1. C++ এ বাইনারি ট্রিতে সর্বাধিক ধারাবাহিক বৃদ্ধি পাথের দৈর্ঘ্য

  2. C++ এ একটি ত্রিভুজে সর্বাধিক পাথ যোগফল

  3. C++ এ দ্বিপক্ষীয় গ্রাফে প্রান্তের সর্বাধিক সংখ্যা

  4. C++ এ 0 এবং 1 এর সেগমেন্টের সর্বোচ্চ দৈর্ঘ্য