Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

3개가 연속되지 않도록 하는 최대 부분 수열 합

<시간/>

이 튜토리얼에서는 3개가 연속되지 않도록 최대 부분수열 합을 찾는 프로그램에 대해 논의할 것입니다.

이를 위해 일련의 양의 정수가 제공됩니다. 우리의 임무는 합 값에서 연속적인 양의 정수를 취하지 않고 최대 합을 찾는 것입니다.

예시

#include <bits/stdc++.h>
using namespace std;
//returning maximum subsequence without involving
//three consecutive numbers
int maxSumWO3Consec(int arr[], int n) {
   int sum[n]; if (n >= 1) sum[0] = arr[0];
   if (n >= 2) sum[1] = arr[0] + arr[1];
   if (n > 2) sum[2] = max(sum[1], max(arr[1] + arr[2], arr[0] + arr[2]));
   for (int i = 3; i < n; i++)
      sum[i] = max(max(sum[i - 1], sum[i - 2] + arr[i]), arr[i] + arr[i - 1] + sum[i - 3]);
   return sum[n - 1];
}
int main() {
   int arr[] = { 100, 1000 };
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << maxSumWO3Consec(arr, n);
   return 0;
}

출력

1100