本题要求编写程序,计算序列部分和 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>
int main()
{
int i,k;
float S,s,j,eps;
i=1;
s=1/(float)i;
scanf("%f",&eps);
while(s>=eps){
j=s;
s=1/(float)(i+3);
if((i+3)%2==0) { S=s-j;}
else if((i+3)%2!=0){S=s+j;}
i++;
}
printf("sum = %.6f",S) ;
return 0;
}
问题:计算错误
修改1
#include<stdio.h>
#include<math.h>
int main(
该篇博客介绍如何用C语言编写程序,计算1 - 1/4 + 1/7 - 1/10 + … 的部分和,直到序列最后一项的绝对值小于给定精度eps。通过示例解释了代码中出现的错误,如误用abs函数,以及精度问题,最终修正代码并成功提交得到正确结果。强调了浮点数精度的区别,指出float和double类型的精度差异。
最低0.47元/天 解锁文章
241

被折叠的 条评论
为什么被折叠?



