ধরুন আমাদের একটি অ্যারে আছে। আমাদের সাবয়েরের সর্বোচ্চ দৈর্ঘ্য খুঁজে বের করতে হবে, যার LCM সেই সাবয়ারের উপাদানগুলির গুণফলের সমান। যদি সেই ধরনের সাবয়ারে পাওয়া না যায়, তাহলে -1 ফেরত দিন। ধরুন অ্যারে হল {6, 10, 21}, তাহলে দৈর্ঘ্য হল 2, যেমন সাবয়ারে {10, 21} আছে, যার LCM হল 210, এবং গুণফলটিও 210৷
পন্থা সোজা এগিয়ে. আমাদের 2 এর থেকে বড় বা সমান দৈর্ঘ্যের প্রতিটি সম্ভাব্য সাবঅ্যারে পরীক্ষা করতে হবে। যদি সাব-অ্যারে শর্তটি সন্তুষ্ট করে, তাহলে উত্তরটি সর্বাধিক উত্তর এবং সাব-অ্যারের দৈর্ঘ্য হিসাবে আপডেট করুন।
উদাহরণ
#include <iostream>
using namespace std;
int gcd(int a, int b) {
if (b == 0)
return a;
return gcd(b, a % b);
}
int maxLengthLCMSubarray(int arr[], int n) {
int len = -1;
for (int i = 0; i < n - 1; i++) {
for (int j = i + 1; j < n; j++) {
long long lcm = 1LL * arr[i];
long long product = 1LL * arr[i];
for (int k = i + 1; k <= j; k++) {
lcm = (((arr[k] * lcm)) / (gcd(arr[k], lcm)));
product = product * arr[k];
}
if (lcm == product) {
len = max(len, j - i + 1);
}
}
}
return len;
}
int main() {
int arr[] = {8, 2, 6, 10, 13, 21, 7};
int n = sizeof(arr) / sizeof(arr[0]);
cout << "Maximum Length: " << maxLengthLCMSubarray(arr, n);
} আউটপুট
Maximum Length: 3