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

C++의 배열에서 (arr[i] – i) – (arr[j] – j) 값 최대화

<시간/>

문제 설명

주어진 배열에서 arr[]은 (arr[i] – i) – (arr[j] – j)의 최대값을 찾습니다. 여기서 i는 j와 같지 않습니다. 여기서 i와 j는 0에서 n-1까지 다양하며 n은 입력 배열 arr[]의 크기입니다.

입력 배열이 {7, 5, 10, 2, 3}이면 다음과 같이 최대값 9개를 얻을 수 있습니다.

(element 10 – index 2) - (element 2 – index 3)
(10 – 2) – (2 – 3) = 8 – (-1) = 9

알고리즘

1. Find maximum value of (arr[i] – i) in whole array.
2. Find minimum value of (arr[i] – i) in whole array.
3. Return difference of above two values

예시

#include <bits/stdc++.h>
using namespace std;
int getMaxDiff(int *arr, int n){
   if (n < 2) {
      cout << "Invalid input" << endl;
      exit(1);
   }
   int minVal = INT_MAX;
   int maxVal = INT_MIN;
   for (int i = 0; i < n; ++i) {
      int result = arr[i] - i;
      if (result > maxVal) {
         cout << "Max = " << arr[i] << " - " << i << endl;
         maxVal = result;
      }
      if (result < minVal) {
         cout << "Min = " << arr[i] << " - " << i << endl;
         minVal = result;
      }
   }
   return (maxVal - minVal);
}
int main(){
   int arr[] = {7, 5, 10, 2, 3};
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << "Maximum value = " << getMaxDiff(arr, n) << endl;
   return 0;
}

출력

위의 프로그램을 컴파일하고 실행할 때. 다음 출력을 생성합니다 -

Maximum value = Max = 7 - 0 
Min = 7 - 0 
Min = 5 - 1 
Max = 10 - 2 
Min = 2 - 3 9