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

C++에서 허용되는 음수가 있는 배열의 쌍별 곱의 최대 합계

<시간/>

이 자습서에서는 음수가 허용되는 배열에서 쌍별 곱의 최대 합을 찾는 프로그램에 대해 설명합니다.

이를 위해 정수를 포함하는 배열이 제공됩니다. 우리의 임무는 pairwise 곱셈을 수행하는 동안 최대 합을 찾는 것입니다.

예시

#include <bits/stdc++.h>
#define Mod 1000000007
using namespace std;
//finding the maximum sum
long long int findSum(int arr[], int n) {
   long long int sum = 0;
   //sorting the array
   sort(arr, arr + n);
   int i = 0;
   while (i < n && arr[i] < 0) {
      if (i != n - 1 && arr[i + 1] <= 0) {
         sum = (sum + (arr[i] * arr[i + 1]) % Mod) % Mod;
         i += 2;
      }
      else
         break;
   }
   int j = n - 1;
   while (j >= 0 && arr[j] > 0) {
      if (j != 0 && arr[j - 1] > 0) {
         sum = (sum + (arr[j] * arr[j - 1]) % Mod) % Mod;
         j -= 2;
      }
      else
         break;
   }
   if (j > i)
      sum = (sum + (arr[i] * arr[j]) % Mod) % Mod;
   else if (i == j)
      sum = (sum + arr[i]) % Mod;
   return sum;
}
int main() {
   int arr[] = { -1, 9, 4, 5, -4, 7 };
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << findSum(arr, n);
   return 0;
}

출력

87