ধরুন আমাদের N বিভিন্ন আয়তক্ষেত্রের প্রস্থ এবং উচ্চতা আছে; একটির মধ্যে আরেকটি ঢোকানোর পর আমাদের ন্যূনতম সংখ্যক আয়তক্ষেত্র বাকি আছে তা খুঁজে বের করতে হবে। সুতরাং, যদি W1 এবং W2 যথাক্রমে R1 এবং R2 আয়তক্ষেত্রের প্রস্থ হয়। এবং H1 এবং H2 যথাক্রমে R1 এবং R2 এর উচ্চতা, তারপর যদি W1
সুতরাং, যদি ইনপুটটি হয় {{ 30, 45 }, { 15, 15 }, { 45, 30 },{60, 75 }}, তাহলে আউটপুট হবে 2 কারণ সম্ভাব্য উপায়গুলির মধ্যে একটি হল দ্বিতীয় আয়তক্ষেত্র সন্নিবেশ করানো প্রথমটিতে এবং তারপর চতুর্থটিতে সেই আয়তক্ষেত্রটি সন্নিবেশ করান। তৃতীয় এবং চতুর্থ আয়তক্ষেত্র বাকি।
এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
n :=বাক্সের আকার
অ্যারে বাক্সগুলিকে তাদের আকারের উপর ভিত্তি করে সাজান
জোড়ার নেস্টেড একটি অ্যারে সংজ্ঞায়িত করুন
নেস্টেডের শেষে বক্সগুলি [n - 1] ঢোকান
আরম্ভ করার জন্য i :=n - 2, যখন i>=0, আপডেট করুন (i 1 দ্বারা কম করুন), −
ডান:=নেস্টেডের আকার
যখন বামে <=ডানে, কর:
মধ্য :=(ডান + বাম) / 2
যদি নেস্টেড[মিড] এর উচ্চতা বাক্সের উচ্চতা [i] বা নেস্টেডের প্রস্থ [মিড] <=বাক্সগুলির প্রস্থ [i] সমান হয়, তাহলে −
বাম :=মধ্য + 1
অন্যথায়
ডান:=মধ্য - 1
বাম যদি নেস্টেডের আকারের সমান হয়, তাহলে −
নেস্টেডের শেষে বক্সগুলি [i] সন্নিবেশ করুন
অন্যথায়
নেস্টেডের প্রস্থ [বাম] :=বাক্সগুলির প্রস্থ[i]
নেস্টেডের উচ্চতা [বাম] :=বাক্সের উচ্চতা[i]
নেস্টেডের রিটার্ন সাইজ
আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -
উদাহরণ
#include <bits/stdc++.h>
using namespace std;
bool comp(const pair<int, int>& L, const pair<int, int>& R) {
if (L.first == R.first)
return L.second > R.second;
return L.first < R.first;
}
int Rectangles(vector<pair<int, int>> &boxes) {
int n = boxes.size();
sort(boxes.begin(), boxes.end(), comp);
vector<pair<int, int< < nested;
nested.push_back(boxes[n - 1]);
for (int i = n - 2; i >= 0; --i) {
int right = nested.size() - 1, left = 0;
while (left <= right) {
int mid = (right + left) / 2;
if (nested[mid].first == boxes[i].first || nested[mid].second <= boxes[i].second)
left = mid + 1;
else
right = mid - 1;
}
if (left == nested.size())
nested.push_back(boxes[i]);
else {
nested[left].second = boxes[i].second;
nested[left].first = boxes[i].first;
}
}
return nested.size();
}
int main() {
vector<pair<int, int>> boxes = {{30, 45}, {15,15}, {45,30},{60,75}};
cout << Rectangles(boxes);
}
ইনপুট
{{30, 45}, {15,15}, {45,30},{60,75}}
আউটপুট
2