C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

級数の合計1+(1 + 2)+(1 + 2 + 3)+(1 + 2 + 3 + 4)+ ... +(1 + 2 + 3 + 4 + ... + n) C ++


この問題では、数nが与えられます。私たちのタスクは、級数1 +(1 + 2)+(1 + 2 + 3)+(1 + 2 + 3 + 4)+…+(1 + 2 + 3 + 4)の合計を見つけるプログラムを作成することです。 + ... + n)。

問題を理解するための例を見てみましょう。

入力

n = 4

出力

20

説明- (1)+(1 + 2)+(1 + 2 + 3)+(1 + 2 + 3 + 4)=20

この問題の簡単な解決策は、2つのループを使用してシリーズを作成することです。

アルゴリズム

Initialize sum = 0
Step 1: Loop for i -> 1 to n i.e i = 1 to i <= n.
   Step 1.1: Loop for j -> 1 to i i.e. i = 1 to i <= i.
   Step 1.1.1: update sum i.e. sum += j.
Step 2: return sum.

ソリューションの動作を説明するプログラム

#include <iostream>
using namespace std;
int calcSeriesSum(int n) {
   int sum = 0;
   for (int i = 1 ; i <= n ; i++)
      for (int j = 1 ; j <= i ; j++)
         sum += j;
   return sum;
}
int main() {
   int n = 7;
   cout<<"Sum of the series 1 + (1+2) + (1+2+3) + (1+2+3+4) + ... + (1+2+3+4+...+"<<n<<") is "<<calcSeriesSum(n);
   return 0;
}

出力

Sum of the series 1 + (1+2) + (1+2+3) + (1+2+3+4) + ... + (1+2+3+4+...+7) is 84

しかし、このアプローチは効果的ではありません。

効果的な解決策は、級数の合計を見つけるための一般式を導き出すことかもしれません。

sum = 1 + (1+2) + (1+2+3) + (1+2+3+4) …
sum = ∑ ( (1+2+3+4+5+...) )
sum = ∑ ( n(n+1)/2)
sum = ½ ∑ ( n^2 + n) = ½ (∑ (n2) + ∑ n)
sum = ½ [ (n(n+1)(2n+1))/6 ) + ½ ( n(n+1)/2 ]
sum = ½ [ (n(n+1))/2 ( (2n+1)/3 + 1) ]
sum = ½ [ ((n(n+1))/2) * (2n + 1 + 3)/3 ]
sum = ½ [ (n(n+1)(2n+4))/6]
sum = (n(n + 1)(2n + 4))/6

ソリューションの動作を説明するプログラム

#include <iostream>
using namespace std;
int calcSeriesSum(int n) {
   return (n*(n + 1)*(2*n + 4))/12;
}
int main() {
int n = 7;
   cout<<"Sum of the series 1 + (1+2) + (1+2+3) + (1+2+3+4) + ... + (1+2+3+4+...+"<<n<<") is "<<calcSeriesSum(n);
}
です

出力

Sum of the series 1 + (1+2) + (1+2+3) + (1+2+3+4) + ... + (1+2+3+4+...+7) is 84

  1. C++でarr[i]*iの合計を最大化します

    問題の説明 N個の整数の配列が与えられます。配列の要素を再配置することができます。タスクは、Σarr[i] * iの最大値を見つけることです。ここで、i =0、1、2、.. n – 1 input array ={4、1、6、2}の場合、要素を並べ替えた順序で並べ替えると、最大合計は28になります- {1, 2, 4, 6} = (1 * 0) + (2 * 1) + (4 * 2) + (6 * 3) = 28 アルゴリズム 1. Sort array in ascending order 2. Iterate over array and multiply each array el

  2. 算術級数の合計のためのC++プログラム

    「a」(第1項)、「d」(共通の差)、「n」(文字列内の値の数)が与えられ、タスクは級数を生成し、それによってそれらの合計を計算することです。 算術級数とは 算術級数は、シリーズの最初の項が「a」で固定され、それらの間の一般的な違いが「d」である、共通の違いを持つ数列です。 -として表されます a、a + d、a + 2d、a + 3d 、。 。 。 例 Input-: a = 1.5, d = 0.5, n=10 Output-: sum of series A.P is : 37.5 Input : a = 2.5, d = 1.5, n = 20 Output : sum of s