#include<stdio.h>
int xxx_fz(int n);
int xxx_fm(int n);
int main()
{
int n,fz,fm,i;
float result=0,item;
printf("您希望以该公式计算的个数为:");
scanf("%d",&n);
fz=xxx_fz(n);
fm=xxx_fm(n);
item=fz/fm;
for(i=1;i<=n;i++)
{
result+=item;
}
printf("%d",result);
return 0;
}
int xxx_fz(int n)
{
int i,first=-1;
for(i=1;i<=n;i++)
{
first=-first;
}
return first;
}
int xxx_fm(int n)
{
int i,ji=1;
for(i=1;i<=n;i++)
{
if(i==1)
{
ji*=(2*i-1);
}
else{
ji*=(2*i-1)*(2*i-2);
}
}
return ji;
}
int xxx_fm(int n) 求阶乘的函数返回值用 int 型,很快就超 int 范围了。
主函数里算法是错误的:
fz=xxx_fz(n);
fm=xxx_fm(n);
item=fz/fm;
for(i=1;i<=n;i++)
{
result+=item;
}