這裡我們會看到一個問題,假設給定一個陣列。有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
以上是數組操作和求和使用C/C++的詳細內容。更多資訊請關注PHP中文網其他相關文章!