#include<stdio.h>
double fact(int n)
{
if (n < 2)
return 1;
else
return fact(n - 1) * n;
}
long long cmp(int n)
{
long long m = 1;
for (int j = 1; j <= n; j += 2)
{
m = j * m;
}
return m;
}
int main()
{
int i = 1;
double eps, s = 1.0, t=1;
scanf("%le", &eps);
while(t >= eps)
{
t = fact(i) / cmp(2 * i + 1);
s = s + t;
i++;
}
printf("PI = %.5lf", s * 2);
return 0;
}
这道求派近似值的题是较为简单的,我尝试复杂化(其实也还好), 其中%le是用科学计数法输出的double数据类型,调用了两个自定义函数,之前cmp函数返回值和m的数据类型都用double,导致最后求派不对头(到后面返回值为负数,是因为超出了数据类型范围),这其中是如何找出错误的呢,那就在于调试了,我是通过一个个printf来找出其中的错误点(还望大佬指正)。
当然了,就这道题来说,还是有更简单的方法滴,如下:
#include<stdio.h>
int main()
{
int i;
double eps,s=1,m=1,n=1,t=1;
scanf("%lf", &eps);
for (i = 1;t>=eps ; i++)
{
m = m * i;
n = n * (2 * i + 1);
t = m / n;
s = s + t;
}
printf("%.5lf", s * 2);
return 0;
}
不知道为什么不调用函数就用double就没毛病。