1156:求π的值
时间限制: 1000 ms 内存限制: 65536 KB
提交数: 16766 通过数: 5447
【题目描述】
根据公式:
arctanx(x)=x−x^3/3+x ^ 5/5−x ^ 7/7+…和π=6arctanx(1/√3)
定义函数 arctanx(x),求当最后一项小于10−6时π的值。
【输入】
(无)
【输出】
π的值。保留到小数点后10位。
【输入样例】
(无)
【输出样例】
(无)
思路:累加求和,分子 x 连乘 正负号错位,分母相差2 的奇数 一直循环处理至一个接近于零的很小的数。
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
double cal(double x);
int main()
{
double a,pi;
a = 1/sqrt(3);
pi = 6 * (cal(a));
printf("%.10lf\n",pi);
return 0;
}
double cal(double x)
{
double sum = 0,tmp = x;
int i = 1;
while(fabs(tmp / i) >= 1e-6)//x−x^3/3+x ^ 5
{
sum += tmp / i; //和累加
tmp=-1 * x * x * tmp; //分子 x 连乘 正负号错位
i += 2;//分母相差2 的奇数
}
return sum;
}
本文介绍了一种基于arctanx(x)级数展开的算法来计算π的值,利用C++编程语言实现了该算法,并通过累加求和的方式得到π的近似值,保留至小数点后10位。
1442

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



