이 문제에서는 다음과 같이 주어진 (n-1)변수의 합으로 구성된 배열 sum[]이 주어집니다.
Sum[1] = x2 + x3 + x4 + … xn Sum[2] = x1 + x3 + x4 + … xn . . Sum[i] = x2 + x3 + x4 + … x(i-1) + x(i+1) + … + xn . . Sum[n] = x1 + x2 + x3 + … x(n-1) Our task is to find the value of x1, x2,... xn.
문제를 이해하기 위해 예를 들어보겠습니다.
입력
sum[] = {6, 6, 6, 6, 6, 6, 6}
출력
x1 = 1, x2 = 1, x3 = 1, x4 = 1, x5 = 1, x6 = 1, x7 = 1
설명
arr[1] = 1 + 1 + 1 + 1 + 1 + 1 = 6
솔루션 접근 방식
모든 변수의 합을 sumX라고 하고,
합계X =x1 + x2 + x3 + ... + xn
따라서 합계 배열의 값은 -
sum[1] = x2 + x3 + x4 + … xn = -x1 + x1 + x2 + x3 + x4 + … xn = sumX - x1
마찬가지로
sum[2] = sumX - x2 sum[3] = sumX - x3 . sum[i] = sumX - xi . sum[n] = sumX - xn
얻은 모든 합계 배열을 더하면
Sum[1] + sum[2] + … sum[n] = sumX - x1 + sumX - x2 + … + sumX - xn arrSum = n*sumX - (x1 + x2 + x3 … xn) arrSum = n*SumX - (x1 + x2 + x3 … xn) arrSum = sumX*(n-1) sumX = arrSum/ (n-1)
이 sumX 값을 사용하여 x1, x2…
의 값을 찾을 수 있습니다.그래서
x1 = sumX - sum[1] x2 = sumX - sum[2] .. xi = sumX - sum[i] .. xn = sumX - sum[n]
우리 솔루션의 작동을 설명하는 프로그램
예시
#include <iostream> using namespace std; void calcSumVariables(int sum[], int n) { float SUMX = 0; for (int i = 0; i < n; i++) { SUMX += sum[i]; } SUMX /= (n - 1); for (int i = 0; i < n; i++) cout<<"\nx"<<(i + 1)<<" = "<<(SUMX - sum[i]); } int main(){ int sum[] = {3, 8, 6, 7, 4, 5, 9 }; int N = sizeof(sum) / sizeof(sum[0]); cout<<"The value of variables that form the sum are "; calcSumVariables(sum, N); return 0; }
출력
합계를 구성하는 변수의 값은 다음과 같습니다.
x1 = 4 x2 = -1 x3 = 1 x4 = 0 x5 = 3 x6 = 2 x7 = -2