本题要求编写程序,计算序列部分和 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
解析:本题的核心在于题中所述“直到最后一项的绝对值不大于给定精度eps” ,根据答案理解后倒推,其意思在于:最后一项若等于给定精度,那么再之后的一项就没必要参与计算;但是如果倒数第二项大于给定精度,最后一项小于给定精度,那么就需要额外补上最后一项,否则就会产生错误。以测试数据举例:eps=4e-2时,最后一项绝对值恰好为1/25与之相等,则就不需要再补一项;而当eps=0.02时,跳出循环的项为1/52,但是由于上一项绝对值并不等于eps,所以此项应该算在内,所以需要补入。补项的思想就在于:检验退出循环的上一项绝对值是否等于eps,若不等表示少了最后一项,所以需要补项。
代码如下:
#include<stdio.h>
#include<math.h>
int main()
{
int n=1;
double eps,sum=0.0;
scanf("%lf",&eps);
while(1.0/(3*n-2)>=eps)
{
if(n%2==0)
{
sum-=(1.0/(3*n-2));
}
else
{
sum+=(1.0/(3*n-2));
}
n++;
}
if(1.0/(3*n-5)!= eps)
{
if(n%2==0)
{
sum-=(1.0/(3*n-2));
}
else
{
sum+=(1.0/(3*n-2));
}
}
printf("sum = %.6f",sum);
return 0;
}