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

2024-11-17 06:36:59
推荐回答(3个)
回答(1):

是只取整数部分的。
也就是,可能是1.999999999
然后转换为int就是1,所以
浮点数向int转换,会丢失精度。
为了避免这个,建议如果想取到整数部分。
可以使用
float b;
int a;
a=(b+0.5);
这样写的话,就是四舍五入。
如果
写成
a=b.
可能有
0.99999999999
被截断,
a就是0的情况。

回答(2):

#include
main()
{
int a1,a2;
float b=5.6,c=3.3;
a1=b;
a2=c;
printf("%d,%d",a1,a2) ;
}
通过这个程序你就可以知道是取整

回答(3):

取整