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

วิธีแก้ปัญหาง่ายๆ ก็คือการสร้างชุดข้อมูลโดยใช้สองลูป

อัลกอริทึม

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