本题要求编写程序,计算序列部分和 1 - 1/4 + 1/7 - 1/10 + … 直到最后一项的绝对值不大于给定精度eps。
输入格式:
输入在一行中给出一个正实数eps。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。
输入样例1:
4E-2
输出样例1:
sum = 0.854457
输入样例2:
0.02
输出样例2:
sum = 0.826310
法1:while循环
# include <stdio.h>
int main()
{
double eps, sum = 0, x = 1;
int de = 1, sign = 1;
scanf_s("%lf",&eps);
while(1.0/de>eps) //或者用fasb()浮点数的取绝对值函数,需要# include <math.h>
{
sum = sum + x;
sign = -sign;
de += 3;
x = 1.0 * sign / de;
}
printf("sum = %.6lf", sum+x);
return 0;
}
法2:do-while循环
# include <stdio.h>
# include <math.h>
int main()
{
double eps, sum = 0, x = 1;
int de = 1, sign = 1;
scanf_s("%lf", &eps);
do {
x = 1.0 * sign / (3 * de - 2);
sum += x;
sign = -sign;
de++;
} while (fabs(x) > eps);
printf("sum = %.6lf", sum);
return 0;
}