首頁 > 後端開發 > C++ > 主體

數組操作和求和使用C/C++

PHPz
發布: 2023-09-02 22:29:06
轉載
1345 人瀏覽過

數組操作和求和使用C/C++

這裡我們會看到一個問題,假設給定一個陣列。有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中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板