我对这个循环有一些问题。这是无限的,但我不知道是什么导致了它。这是长代码的一部分,所以我只是发布它的一部分 我应该为此使用Machin的近似序列,并且它应该只有.001误差范围(因此在while循环上的操作)
int main(void){
int opcion=0, contLeib, banderaLeib, contWallis, bandWallis;
float piLeib=0.0, sumaLeib=0.0, piLeibT=3.1415, piWallis=1.0, sumaWallis=0.0, nom, numWallis, denWallis, doble, sumaMachin=0.0, restaMachin=0.0;
bandWallis=1;
doble=1.0;
piWallis=1.0;
sumaMachin=0.0;
restaMachin=0.0;
contWallis=1;
while(sqrt(pow(piLeibT-(4.0*piWallis), 2))>.001){
if((contWallis%2)!=0){
if(bandWallis==1){
doble=contWallis*1.0;
sumaMachin= sumaMachin + 1/(doble*pow(5,doble));
restaMachin= restaMachin + 1/(doble*pow(239,doble));
bandWallis=0;
} else {
sumaMachin= sumaMachin - 1/(doble*pow(5,doble));
restaMachin= restaMachin - 1/(doble*pow(239,doble));
bandWallis=1;
}
contWallis++;
piWallis= 4.0 * (sumaMachin-restaMachin);
}
else{
contWallis++;
}
}
nom = piWallis*4.0;
printf("\n%f", nom);
return 0;
}
答案 0 :(得分:0)
在初始化之前使用contWallis
。
假设您按照评论中的建议将其设置为1
,在while循环的第二次迭代中,if ((contWallis%2)!=0)
的值将为false,因此您将永远不会输入该条件的主体,然后你永远不会改变循环迭代和任何后续循环的任何变量的值。