#include <stdio.h>
#include <math.h>
int main()
{
float PI;
int x,n;
x=3;
n=1;
PI=1;
do
{
PI+=pow(-1,n)/x;
x=x+2;
n++;
}while(1.0/x>1e-8);
printf("PI=%7.5f\n",4.0*PI);
return 0;
}
算圆周率答案不对总是差一点或者什么也没有
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- bingbingyihao 2022-11-12 00:09关注
回答:你这是用泰勒逼近计算对吧,你的精度定的太高,计算机计算需要一些时间,代码是没问题的
#include <stdio.h> #include <math.h> int main() { float PI; int x, n; x = 3; n = 1; PI = 1; do { PI += pow(-1, n) / x; x = x + 2; n++; } while (1.0 / x > 1e-8); printf("Over\n"); printf("PI=%7.5f\n", 4.0 * PI); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥60 pb数据库修改或者求完整pb库存系统,需为pb自带数据库
- ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
- ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
- ¥20 神经网络Sequential name=sequential, built=False
- ¥16 Qphython 用xlrd读取excel报错
- ¥15 单片机学习顺序问题!!
- ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
- ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
- ¥15 相敏解调 matlab
- ¥15 求lingo代码和思路