在这个问题上,我们得到n个数项。该级数为0.7、0.77、0.777…。我们的任务是创建一个程序来查找系列0.7、0.77、0.777…最多n个项的sim。
输入 4
输出结果
说明-0.7 + 0.77 + 0.777 + 0.7777 = 3.0247
为了解决这个问题,我们将导出级数和的公式。让我们找到它的一般公式,
sum = 0.7 + 0.77 + 0.777 + ... upto n terms sum = 7 (0.1 + 0.11 + 0.111 + … upto n terms) sum = 7 (9/9)(0.1 + 0.11 + 0.111 + … upto n terms) sum = 7/9(0.9 + 0.99 + 0.999 + … upto n terms) sum = 7/9 ( (1 - 0.1) + (1 - 0.01) + (1 - 0.001) + … upto n terms ) sum = 7/9 ( (1+ 1 + 1 + … + upto n) - (0.1 + 0.01 + 0.001 + … upto n terms) ) sum = 7/9 ( (n) - (1/10 + 1/100 + 1/1000 + … upto n terms) ) sum = 7/9 ( n - 0.1 * ((1 - (0.1)n)/ (1 - 0.1)) ) sum = 7/9 ( n - 0.1 * ((1 - (0.1)n)/ (0.9)) ) sum = 7/9 ( n - ((1 - (1/10n) )/9) ) sum = 7/81 ( 9n - (1 - (1/10n) ) ) sum = 7/81 (9n - 1 + 10-n)
该公式给出了最多n个项之和的一般公式。
该程序说明了我们解决方案的工作原理,
#include <iostream> #include <math.h> using namespace std; float calcSeriesSum(int n) { return ( (.08641) * (9*n - 1) + pow(10, (-1) * n) ); } int main() { int n = 5; cout<<"The sum of series 0.7, 0.77, 0.777, ... upto n terms is "<<calcSeriesSum(n); return 0; }
输出结果
The sum of series 0.7, 0.77, 0.777, ... upto n terms is 3.80205