মডিউল ১৯-৬ঃ Reverse Level Order Traversal (Coding Ninjas)

প্রবলেম লিংকঃ Reverse Level Order Traversal - Coding Ninjasarrow-up-right

প্রবলেম স্টেটমেন্টঃ একটি ট্রি দেওয়া থাকবে। সেই ট্রি এর নোডগুলো লেভেল অর্ডারে প্রিন্ট করতে হবে কিন্তু রিভার্স করে। সল্যুশনঃ খুব সহজেই এটি করে ফেলা যাবে। আমরা গত মডিউলে দেখানো কিউ দিয়ে লেভেল অর্ডারে ট্রাভারস করে নোডগুলোকে একটি ভেক্টরে রেখে দিব। তারপর সেই ভেক্টরকে রিভার্স করে রিটার্ন করে দিলেই হয়ে যাবে।

#include <bits/stdc++.h>
vector<int> reverseLevelOrder(TreeNode<int> *root)
{
    vector<int> v;       // ভেক্টর নিচ্ছি। 
    queue<TreeNode<int> *> q;     // লেভেল অর্ডারে ট্রাভারস করার জন্য কিউ নিচ্ছি। 
    if (root)           // গত মডিউলে দেখানো লেভেল অর্ডার ট্রাভারসাল।
        q.push(root);
    while (!q.empty())
    {
        TreeNode<int> *node = q.front();
        q.pop();
        v.push_back(node->val);      // ভেক্টরে পুশ করা হচ্ছে। 
        if (node->left)
            q.push(node->left);
        if (node->right)
            q.push(node->right);
    }
    reverse(v.begin(), v.end());     // ট্রাভারস শেষে ভেক্টর রিভার্স করে দেওয়া হচ্ছে।
    return v;
}

Last updated