根據公式,π/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;
}