本题要求编写程序,计算序列部分和 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>
#include<string.h>
int main()
{
double eps,sum=1,p=1,t=1;
scanf("%lf",&eps);//double型用 %lf 输入
//t和sum在声明时定义为1,如果eps大于首项1,直接跳过循环,输出sum=1.000000
//如果进入循环,相当于直接从第二项开始(2)
//注意题干,尾项恰好等于eps仍要参与运算(1)
while((1.0/t)>eps){//这里while的判断既时入口条件判断,同时由于进入循环之后t才更新,
//又有点出口条件判断的感觉
t+=3;
p=-p;//产生交错效果,效率应该要高于调用 pow(i,项数)函数(3)
sum+=p/t;//如果p声明的是整型变量,这里可以用 (p+0.0)
//或者 (double)p 来强制转换(4)
}
printf("sum = %lf",sum);
return 0;
}
(1)这题在理解 “直到最后一项的绝对值不大于给定精度eps” 这句话时可能会有觉得点绕。
(2)t和sum在声明时定义为1,如果eps大于首项1,直接跳过循环,输出sum=1.000000;如果进入循环,相当于直接从第二项开始
(3)在实现交错项时,可能会想到 (-1)^项数 进而调用 pow()函数,但是pow()函数的调用是低效的,尤其是本身就很简单的操作,所以这里直接用 - 运算符变号。
(4)浮点数的除法,对结果是否为浮点型起绝对作用的是分子,浮点型分子,运算结果就是浮点型,整型分子,结果也是整型,与分母无关。