|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
7-10 用格里高利公式求给定精度的PI值
分数 10
作者 颜晖
单位 浙大城市学院
本题要求编写程序,计算序列部分和 4∗(1−1/3+1/5−1/7+...) ,直到最后一项的绝对值小于给定精度eps。
输入格式:
输入在一行中给出一个正实数eps。
输出格式:
在一行中按照“Pi = pi”的格式输出部分和的值pi,精确到小数点后四位。题目保证输入数据和计算结果均不超过双精度范围。
输入样例1:
0.0001
输出样例1:
Pi = 3.1418
输入样例2:
0.2
输出样例2:
Pi = 2.8952
#include<stdio.h>
#include<iostream>
#include<iomanip>
#include<math.h>
using namespace std;
int main(void)
{
double sum=0.0;double c;
cin>>c;int d;int i=1;
d=pow(-1,i-1);
while(fabs(1.0/(2*i-1))>=c)
{
sum+=1.0*d/(2*i-1);
i++;
}
cout<<"Pi = "<<4*sum<<endl;
}
我这样写为什么是错的,帮忙看看应该怎么改
你的代码存在一些问题。首先,你在循环条件中使用了 fabs(1.0/(2*i-1))>=c ,这是错误的。应该使用 fabs(1.0/(2*i-1))>=eps ,因为题目要求最后一项的绝对值小于给定精度 eps 。
其次,你没有在循环中更新 d 的值。根据题目要求,每次循环都需要取相反的符号,所以你需要在循环内部更新 d 的值,可以使用 d = -d 来实现。
最后,你在输出结果时没有控制小数点后的位数。题目要求结果精确到小数点后四位,你可以使用 setprecision(4) 来设置输出的精度。
下面是修改后的代码:
- #include <iostream>
- #include <iomanip>
- #include <cmath>
- using namespace std;
- int main() {
- double sum = 0.0;
- double eps;
- cin >> eps;
- int i = 1;
- int d = 1;
- while (fabs(1.0 / (2 * i - 1)) >= eps) {
- sum += 1.0 * d / (2 * i - 1);
- d = -d;
- i++;
- }
- cout << fixed << setprecision(4) << "Pi = " << 4 * sum << endl;
- return 0;
- }
复制代码
希望对你有帮助!如果还有其他问题,请随时提问。
|
|