本题要求编写程序,计算序列部分和 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 <stdio.h>
#include <math.h>
double sum ( double n);
int main(void)
{
double n;
scanf("%lf", &n);
printf("sum = %.6f\n", sum(n));
return 0;
}
//没想出更漂亮的解决办法(我可太笨了),如果您知道请告诉我 -。-
double sum ( double n )
{
int sign = 1;
double result = 0;
double temp = 0;
int i = 1;
while (1)
{
temp = (sign) * (1.0/i);
sign *= -1;
i += 3;
if (fabs(temp) > n)
{
result += temp;
}
else
{
result += temp;
return result;
}
}
}