ホームページ > バックエンド開発 > C++ > C/C++ を使用した配列演算と合計

C/C++ を使用した配列演算と合計

PHPz
リリース: 2023-09-02 22:29:06
転載
1388 人が閲覧しました

C/C++ を使用した配列演算と合計

ここでは、配列が与えられたと仮定して、問題が発生します。 n個の要素があります。別の値 S も与えられます。 K より大きいすべての要素が K に等しい場合、最終的な配列のすべての要素の合計が S に等しくなるように、配列内の要素 K を見つける必要があります。不可能な場合は、-1 が返されます。

要素が {12, 6, 3, 7, 8} で合計値が 15 であると仮定すると、出力は 3 になります。最終的な配列は {3, 3, 3, 3, 3} で、配列要素の合計は S = 15

Algorithm

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 サイトの他の関連記事を参照してください。

ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート