여기서 우리는 하나의 배열이 주어진다고 가정할 때 하나의 문제를 보게 될 것입니다. n개의 요소가 있습니다. 다른 값 S도 제공됩니다. 배열에서 요소 K를 찾아야 합니다. 따라서 K보다 큰 모든 요소가 K와 같게 되면 최종 배열의 모든 요소의 합이 S와 같아집니다. 이것이 가능하지 않은 경우, 그런 다음 -1을 반환합니다.
요소가 {12, 6, 3, 7, 8}이고 합계 값이 15이고 출력이 3이라고 가정합니다. 최종 배열은 {3, 3, 3, 3, 3}이고 배열 요소의 합계는 S =15
알고리즘
getVal(arr, n, S) -
Begin sort arr as increasing order sum := 0 for i in range 0 to n-1, do if sum + (arr[i] * (n - i)) is same as S, then return arr[i] end if sum := sum + arr[i] done return -1 End
예시
#include <iostream>
#include <algorithm>
using namespace std;
int getVal(int arr[], int n, int S) {
sort(arr, arr + n);
int sum = 0;
for (int i = 0; i < n; i++) {
if (sum + (arr[i] * (n - i)) == S) //if current value is satisfying, then return arr[i]
return arr[i];
sum += arr[i];
}
return -1;
}
int main() {
int S = 15;
int arr[] = { 12, 3, 6, 7, 8 };
int n = sizeof(arr) / sizeof(arr[0]);
cout << getVal(arr, n, S);
} 출력
3