এখানে আমরা দেখব কিভাবে একটি অ্যারের প্রতিটি উপাদানের জন্য সবচেয়ে কাছের মান খুঁজে বের করা যায়। যদি একটি এলিমেন্ট x-এর পরবর্তী এলিমেন্ট থাকে যা তার থেকে বড় এবং অ্যারেতেও উপস্থিত থাকে, তাহলে সেটি হবে সেই উপাদানটির বৃহত্তর মান। যদি উপাদানটি উপস্থিত না থাকে তবে -1 ফেরত দিন। ধরুন অ্যারের উপাদানগুলি হল [10, 5, 11, 6, 20, 12], তাহলে বৃহত্তর উপাদানগুলি হল [11, 6, 12, 10, -1, 20]। যেহেতু অ্যারেতে 20 এর বেশি মান নেই, তাহলে প্রিন্ট -1।
এটি সমাধান করতে, আমরা C++ STL-এর সেটিংস ব্যবহার করব। সেটটি বাইনারি ট্রি পদ্ধতি ব্যবহার করে প্রয়োগ করা হয়। বাইনারি ট্রিতে সর্বদা ইন-অর্ডার উত্তরাধিকারী পরবর্তী বড় উপাদান। তাই আমরা O(log n) সময়ে উপাদানটি পেতে পারি।
উদাহরণ
#include<iostream> #include<set> using namespace std; void nearestGreatest(int arr[], int n) { set<int> tempSet; for (int i = 0; i < n; i++) tempSet.insert(arr[i]); for (int i = 0; i < n; i++) { auto next_greater = tempSet.upper_bound(arr[i]); if (next_greater == tempSet.end()) cout << -1 << " "; else cout << *next_greater << " "; } } int main() { int arr[] = {10, 5, 11, 6, 20, 12}; int n = sizeof(arr) / sizeof(arr[0]); nearestGreatest(arr, n); }
আউটপুট
11 6 12 10 -1 20