C语言中对于浮点数进行(int)转换时,计算机是按照四舍五入呢?还是只取整数部分?

如题所述

是只取整数部分的。
也就是,可能是1.999999999
然后转换为int就是1,所以
浮点数向int转换,会丢失精度。
为了避免这个,建议如果想取到整数部分。
可以使用
float b;
int a;
a=(b+0.5);
这样写的话,就是四舍五入。
如果
写成
a=b.
可能有
0.99999999999
被截断,
a就是0的情况。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2010-05-26
#include <stdio.h>
main()
{
int a1,a2;
float b=5.6,c=3.3;
a1=b;
a2=c;
printf("%d,%d",a1,a2) ;
}
通过这个程序你就可以知道是取整
第2个回答  2010-05-26
取整