c语言如何把一个浮点变量精确到2位小数_Assembly 浮点表示法

非整形的二进制数

在第一章讨论数制的时候,我们只讨论了整形。显然,和十进制一样,其它进制必须也能表示非整形数。在十进制中,在小数点右边的数字关联了10的负乘方值: 9c3811c78da0c3782ae887031d73dc0e.png 不必惊讶,二进制也是以同样的方法表示: c54797d84b3ec3d1b85f51787b891135.png 这个办法与第一章中的整形办法相结合就可以用来转换一个一般数值: 6b878550e5d8c4e4aebf1bd7315acbb4.png 将十进制转换成二进制也不是很难。一般来说,需将十进制数分成两块:整数部分和分数部分。使用第一章中的方法来将整数部分转换成二进制。分数部分的转换可以使用下面描述的方法。 考虑一个用a、b、c···标记比特位的二进制分数。这个数用二进制表示为: 0.abcdef... 将此数乘2.新得到的数的二进制表示将是: a.bcdef... 注意,第一个比特位现在在权值为1的位置。用0替换a得到: 0.bcdef... 再乘以2得到: b.cdef... 现在第二个比特位(b)在权值为1的位置。重复这个过程,直到得到了需要的尽可能多的比特位。图6.1展示了一个实例:将0.5625转换成二进制。这种方法当分数部分为0了才停止。 342612803fb4bd6c145ed30a7324a0d2.png 另一个例子,将23.85转换成二进制。将整数部分 6a780a61bf63dacae2f43cfa9f1e2148.png转换成二进制是容易的,但是分数部分呢?图6.2展示了这个计算的开始部分。如果你仔细看了这个数值,就会发现一个无限循环。这就意味着0.85是一个无限循环的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值