c++ float强制转换成int类型

floatx=11.20;inty=(int)x;intz=(int)(100*(x-y));cout<<z;z为什么会是19,而不是20呢?... float x = 11.20;

int y = (int)x;
int z = (int)(100 * (x - y));
cout<<z;
z为什么会是19, 而不是20呢?
展开
 我来答
XHHISEA02274
推荐于2017-09-06 · TA获得超过8万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:3463万
展开全部

直接用(int)后接需要转换的变量,但是需要强调,转换方式为去掉二进制数小数点后部分的数字!

具体如下:

说明:图中数字都是以二进制方式存储的,所以x=1011.0011 0011 0011 0011......B

强制转换后,去掉小数点后部分数字,所以y=11D;

所以x-y=0.0011 0011 0011 0011.......B =0.1999999......D

所以100(x-y)=19.99999.......D

强制转换后只去掉小数点后部分的数字,所以z=19.

蓝色和清风
推荐于2017-09-03 · 超过53用户采纳过TA的回答
知道小有建树答主
回答量:115
采纳率:0%
帮助的人:108万
展开全部
浮点数在计算机中以二进制存储的,有些数用二进制表示,是无限循环的,, 会丢失一些精度,,
更多追问追答
追问
额, 计算机所有的数据都是二进制存储的啊
追答
有些小数用二进制表示会有无数位,
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式