이 문제에서는 문자 배열이 제공됩니다. 우리의 임무는 C++에서 첫 번째 요소와 마지막 요소가 동일한 부분 배열의 최대 길이를 인쇄하는 프로그램을 만드는 것입니다.
문제를 이해하기 위해 예를 들어보겠습니다.
입력 - 배열 ={'t', 'u', 't', 'o', 'r', 'i', 'a', 'l', 's', 'p', 'o', 'i ', 'n', 't' }
출력 − 14
설명 -
하위 배열 {'t', 'u', 't', 'o', 'r', 'i', 'a', 'l', 's', 'p', 'o', 'i' , 'n', 't' } t로 시작하고 끝납니다.
이 문제를 해결하기 위해 배열에서 첫 번째와 마지막 항목을 찾은 다음 공식을 사용하여 −
하위 배열 길이 =lastOccurrence - firstOccurrence + 1
모든 결과의 최대 길이를 찾습니다.
해법을 이해하기 위해 예를 들어 보겠습니다.
배열 ={a, b, a, c, b, a}
요소 a, 인덱스 0에서 첫 번째 발생, 인덱스 5에서 마지막 발생
하위 배열 길이 =5 - 0 + 1=4
최대 길이 =6
요소 b , 인덱스 1에서 처음 발생, 인덱스 4에서 마지막 발생
하위 배열 길이 =4 - 1 + 1 =4
최대 길이 =6
예시
첫 번째 요소와 마지막 요소가 동일한 하위 배열의 최대 길이를 인쇄하는 프로그램 -
#include <iostream>
using namespace std;
int maxSubArrLength(string arr, int n){
int firstOccurrence, lastOccurrence = -1;
int maxlength = 0;
char ch;
for (int i = 0; i < n; i++){
ch = arr[i];
firstOccurrence = lastOccurrence = i;
for(int j = i; j<n; j++){
if(arr[j] == ch)
lastOccurrence = j;
}
maxlength = max(maxlength, (lastOccurrence - firstOccurrence + 1));
}
return maxlength;
}
int main(){
string arr = "tutorialsPoint";
int n = arr.length();
cout<<"The maximum length of subarray whose first and last elements are same is "<<maxSubArrLength(arr, n);
return 0;
} 출력
The maximum length of subarray whose first and last elements are same is 14