标题: 提高浮点数变整数的精度 这个方法很不错 [打印本页]

作者: 51黑科研    时间: 2016-5-11 04:24
标题: 提高浮点数变整数的精度 这个方法很不错
在我们的产品设计中,经常会遇到浮点数变整数的时候,那么,我们首先看看,浮点数变整数的精度如何?

实验一:分别定义一个浮点数26.6和26.4,把这个数强制转换成整数后,是多少?

下面是我做实验用的程序:





按理说,或者说,我们希望的结果,应该是四舍五入的27和26,但是实际上....



十六进制的1A,就是十进制的26.

我们看到了,结果是程序只取了整数部分,小数部分根本没有给我们四舍五入。

解决办法:

只要你的脑袋瓜聪明,可以想出很多解决。

下面我说一下我的解决办法:

实验二:利用modf函数,把小数和整数分离出来,如果小数小于0.5,就直接取整,如果小数大于等于0.5,就整数+1.

用modf函数,需要调用头文件math.h




最后输出的结果是:



十六进制的1B和1A转换成十进制,就是27和26,这时候,结果就和我们想要的一样了。

你能想出更简便的办法来吗?想出来的话,不防分享到微信论坛,点击文章后面的【阅读原文】就可以进入论坛了。


作者: mcza30    时间: 2016-5-12 09:35
u16 ix,iy;
float x=26.6,y=26.4;

ix=x+0.5;
iy=y+0.5;





欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1