根据公式,π/4=1-1/3+1/5-1/7+.....,直到最后一项小于1e-6。
#include
#include
main()
{
double pi=0,n=1,i=0;
while(fabs(n)>=1e-6)
{
n=(pow(-1,i))*1/(2*i+1);
pi=pi+n;
i++;
}
pi=pi*4;
printf("pi=%10.8f",pi);
return 0;
}
#include
#include
main()
{
int sign=1;
double pi=0,n=1,term=1;
while(fabs(term)>=1e-6)
{
pi=pi+term;
n=n+2;
sign=-sign;
term=sign/n;
}
pi=pi*4;
printf("%10.8f",pi);
return 0;
}
第二段代码结果没错,第一段代码的结果为什么第六位小数不一样。
第一个是相当于比较完了再累加
第二个是相当于累加完了再比较
最后差了一个值
第一个函数改成下面就和第二个一样了
main()
{
double pi=0,n=1,i=0;
n = (pow(-1, i)) * 1 / (2 * i + 1);
while (fabs(n) >= 1e-6)
{
pi = pi + n;
i++;
n = (pow(-1, i)) * 1 / (2 * i + 1);
}
pi=pi*4;
printf("pi=%10.8f",pi);
return 0;
}
应该是浮点数的特殊存储导致的,所以你可以去看看浮点数是如何在没错中表示的,就明白了
pow好像只能用于double类型的。
http://c.biancheng.net/cpp/html/189.html