本题要求编写程序,计算序列部分和 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
来源:
来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/12/exam/problems/282
提交:
题解:
#include<stdio.h>
#include<math.h>
int main(void) {
double eps;
scanf("%lf", &eps);
// flag 为第 i 项 item 的符号
int flag = 1;
// denominator 为第 i 项 item 的分母
int denominator = 1;
// 第 i 项的值
double item = flag * 1.0 / denominator;
double sum = 0;
// 若给定精度大于等于 1,则从第二项开始所有项的值均小于所给精度 eps,那么 sum 的值即为第一项的值
if (eps >= 1) {
sum += item;
} else {
// 使用 fabs 获得浮点数的绝对值
while (fabs(item) > eps) {
item = flag * 1.0 / denominator;
sum += item;
flag = -flag;
denominator += 3;
}
}
printf("sum = %.6lf\n", sum);
return 0;
}