问题描述
- 这个题目为什么第二个输入输出是对应的,而第一个输入输出不对应
-
本题要求编写程序,计算序列部分和 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#include
#include
#include
int main()
{
int i=1;
double eps;
double j=1.0,k,s=0.0;
scanf("%lf",&eps);
do
{
k=i/j;
i=-i;
j+=3;
s+=k;
}
while(fabs(k)>=eps);
printf("sum = %.6lfn",s);
return 0;
}
解决方案
lz的主要问题是最后一项的绝对值不大于给定精度eps,所以需要在相加以前判断。
解决方案二:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main()
{
int i=1;
double eps;
double j=1.0,k,s=0.0;
scanf("%lf",&eps);
while(true)
{
k=(double)i/j;
if (fabs(k)<eps) break;
i=-i;
j+=3;
s+=k;
}
printf("sum = %.6lfn",s);
return 0;
}
解决方案三:
j 已经是 double 类型,加 (double)就是脱裤子放屁多此一举!
时间: 2024-10-31 10:50:36