//本题要求编写程序,计算序列部分和 4∗(1−1/3+1/5−1/7+...) ,直到最后一项的绝对值小于给定精度eps,
//输入0.0001 输出3.1414 输入0.2 输出2.8952
#include<stdio.h>
#include<math.h>
int main()
{
int n=1,flag=1;
double sum=0,eps;
scanf("%lf",&eps);
while(fabs(1.0/(2*n-1))>=eps)
{
sum=sum+1.0*flag/(2*n-1);
flag=-flag;
n++;
}
printf("Pi = %.4lf\n",4*sum);
return 0;
}
为什么我这个不对,是损失精度了吗
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- fuill 2022-01-08 13:56关注
改成这样,你那个出错是因为n已经++了,再判断的
//本题要求编写程序,计算序列部分和 4?(1?1/3+1/5?1/7+...) ,直到最后一项的绝对值小于给定精度eps, //输入0.0001 输出3.1414 输入0.2 输出2.8952 #include<stdio.h> #include<math.h> int main() { int n=1,flag=1; double sum=0,eps; scanf("%lf",&eps); while(fabs(1.0/(double)(2*(n-1)-1))>=eps) { sum=sum+1.0*flag/(double)(2*n-1); flag=-flag; n++; } printf("Pi = %.4lf\n",4*sum); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥20 keepalive配置业务服务双机单活的方法。业务服务一定是要双机单活的方式
- ¥50 关于多次提交POST数据后,无法获取到POST数据参数的问题
- ¥15 win10,这种情况怎么办
- ¥15 如何在配置使用Prettier的VSCode中通过Better Align插件来对齐等式?(相关搜索:格式化)
- ¥100 在连接内网VPN时,如何同时保持互联网连接
- ¥15 MATLAB中使用parfor,矩阵Removal的有效索引在parfor循环中受限制
- ¥20 Win 10 LTSC 1809版本如何无损提升到20H1版本
- ¥50 win10 LTSC 虚拟键盘不弹出
- ¥30 微信小程序请求失败,网页能正常带锁访问
- ¥15 Matlab求解微分方程,如何用fish2d进行预优?