ここでは、配列が与えられたと仮定して、問題が発生します。 n個の要素があります。別の値 S も与えられます。 K より大きいすべての要素が K に等しい場合、最終的な配列のすべての要素の合計が S に等しくなるように、配列内の要素 K を見つける必要があります。不可能な場合は、-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
以上がC/C++ を使用した配列演算と合計の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。