C++中1 + (1+2) + (1+2+3) + (1+2+3+4) + ... + (1+2+3+4+...+n)級數的和
在這個問題中,我們給定一個數字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
解決這個問題的一個簡單方法是使用兩個迴圈建立級數。
演算法
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
廣告
資料結構
網路
關係型資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP