小数的二进制和十六进制表示

您所在的位置:网站首页 勤劳勇敢坚强自信的句子 小数的二进制和十六进制表示

小数的二进制和十六进制表示

#小数的二进制和十六进制表示| 来源: 网络整理| 查看: 265

简述

今天在研究生复试面试的过程中被问到小数的二进制和十六进制形式怎么表示,然而这个知识点已经记不得了,只能尴尬的和老师说这个知识点没有掌握好,回去会继续学习。不过其他答的还可以,最后的成绩不错,回去查了下小数的二进制和十六进制的表示方法,在这里做一个记录。

十进制小数转N进制小数,方法为小数部分乘N取整,每次乘以相应基数之后取结果的整数部分即可。需要注意的是并非所有的十进制小数都能完全转化为N进制小数,这时就需要取近似值。下面详细说下十进制小数转为二进制小数和十六进制小数的方法。

 

小数用二进制表示

首先,给出一个任意实数,整数部分用普通的二进制便可以表示,这里只说小数部分如何表示

这里以0.6为例:

文字描述该过程如下:将该数字乘以2,取出整数部分作为二进制表示的第1位;然后再将小数部分乘以2,将得到的整数部分作为二进制表示的第2位;以此类推,直到小数部分为0。 特殊情况: 小数部分出现循环,无法停止,则用有限的二进制位无法准确表示一个小数,这也是在编程语言中表示小数会出现误差的原因

下面我们具体计算一下0.6的小数表示过程

0.6 * 2 = 1.2 —————— 1 0.2 * 2 = 0.4 —————— 0 0.4 * 2 = 0.8 —————— 0 0.8 * 2 = 1.6 —————— 1 0.6 * 2 = 1.2 —————— 1 ......

我们可以发现在该计算中已经出现了循环,0.6用二进制表示为 1001 1001 1001 1001 …… 

如果是10.6,那么10.6的完整二进制表示为 1010.100110011001……

 

小数用十六进制表示

同样,整数部分用普通的十六进制表示就可以,这里只说小数部分如何表示

这里以0.9为例:

文字描述该过程如下:将该数字乘以16,取出整数部分作为十六进制表示的第1位;然后再将小数部分乘以16,将得到的整数部分作为十六进制表示的第2位;以此类推,直到小数部分为0。

具体计算一下0.9小数表示过程

0.9 * 16 = 14.4 —————— E 0.4 * 16 = 6.4 —————— 6 0.4 * 16 = 6.4 —————— 6 ......

该计算中已经出现了循环,0.9用十六进制表示为 0XE6666.....

如果是10.9,那么10.9的十六进制为0XA.E6666.....

 

二进制表示的小数转换为十进制

其实这个问题很简单,我们再拿0.6的二进制表示举例:1001 1001 1001 1001 

文字描述:从左到右,v[i] * 2^( - i ), i 为从左到右的index,v[i]为该位的值,直接看例子:

0.6 = 1 * 2^-1 + 0 * 2^-2 + 0 * 2^-3 + 1 * 2^-4 + ……

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3