(float)的作用
#include<stdio.h>int main()
{
int n;
float S=0;
for(n=1;S<=3;n++)
{
S=S+1/(float)(2*n-1);
}
printf("%d\n",n);
return 0;
}
为什么加了(float)才能出正确结果,直接把n设成浮点数也不行 你输出n是整数型%d,如果用浮点型float n的话你要把 %d(整数型输出) 改成 %f(浮点型输出) 才能输出答案 n是整型,s是浮点型。
表达式:s=s+1/(float)(2*n-1)。如果不加float,那么表达式s一直小于3,就不会跳出循环,所以程序在运行的时候没有输出n的值。因为1/(2*n-1)当n=1,2,3时分别是1,0,0。所以如果不强制转换程序就会有问题。C语言中除法和数学中除法稍微有点区别。
页:
[1]