C++四舍五入问题
主要是四舍五入的问题,查阅资料后:
C++中:
注意:强制转换不能四舍五入,4.9999–>4 ,只会把小数都删了。
①直接用<math.h> 中的 round 函数:
- 保留到整数:
round(float_value)
可以进行四舍五入,保留到整数。 - 保留n位小数:
round(float_value*pow(10,n) *pow(10,-n)
,可以四舍五入到n位小数
②利用强制转换,但是需要加减一个值
- 例如:保留到整数位,正数需要+0.5,负数-0.5
float a=1.7; float b=1.2;
四舍五入:(int)(a+0.5) -->2; (int)(b+0.5) -->1