简述

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

十进制小数转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 + ……

小数的二进制和十六进制表示相关推荐

  1. 带小数的二进制与十六进制互相转换(超暴力版)

    啊,就写着玩了,很暴力 如果转换后的字符串是回文串,顺便输出个 Beautiful #include <bits/stdc++.h> #define endl '\n' using nam ...

  2. 十六进制表示_计算机为什么用二进制和十六进制

    现代计算机的存储和处理的信息以二值信号来表示,这些用0和1来表示的二进制数字,形成了数字革命的基础.对于有10个手指的人类来说,使用十进制表示法是很自然的事情,但是对构造存储和处理信息的机器来说,二进 ...

  3. 数的进制转换:十进制转二进制、十六进制转二进制、二进制转八进制

    一.十进制整数转其它进制(除基取余法) 十进制数转n进制就是用数不断除以n,直到最后得出的商为0,然后把得出的所有余数倒序排列即为结果. 例1:如下十进制数96转换为二进制数是1100000 例2:如 ...

  4. java 进制转换,二进制 十进制 十六进制 正数 负数的进制等等!

    2进制CPU使用,8进制很少见,10进制适合人类使用,16进制适合编译器和底层程序员使用,希望对你有所帮助! 以下文章是自己从别的地方复制粘贴过来, 总结了一下. 虽然看着有点乱, 但是想学 ,就能看 ...

  5. c语言中十进制转化二进制八进制十六进制,进制转换:二进制、八进制、十六进制、十进制之间的转换...

    对于基础薄弱的读者,本节的内容可能略显晦涩和枯燥,如果觉得吃力,可以暂时跳过,用到的时候再来阅读.但是本节所讲的内容是学习编程的基础,是程序员的基本功,即使现在不学,迟早也要回来学. 上节我们对二进制 ...

  6. 十进制转换成二进制和十六进制的方法

    十进制转换成二进制和十六进制的方法 十进制数转换成二进制数-般分为两个步骤,即整数部分的转换和小数部分的转换. (1 )整数部分的转换 *除2取余法:*这种方法是由于D10=N2 =dn-1x2n-1 ...

  7. 计算机一级二进制转十六进制,计算机进制之二进制、十进制、十六进制之间的转换...

    释放双眼,带上耳机,听听看~! 1.计算机的数制介绍 数制:计数的方法,指用一组固定的符号和统一的规则来表示数值的方法 数位:指数字符号在一个数中所处的位置 基数:指在某种进位计数制中,数位上所能使用 ...

  8. 二进制,十进制,十六进制

    生活中其实很多地方的计数方法都多少有点不同进制的影子. 比如我们最常用的10进制,其实起源于人有10个指头.如果我们的祖先始终没有摆脱手脚不分的境况,我想我们现在一定是在使用20进制. 至于二进制-- ...

  9. 十进制转换成十六进制c语言 链栈,C语言 链栈 实现十进制转换二进制,八进制,十六进制...

    C语言 链栈 实现十进制转换二进制,八进制,十六进制 (3页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 11.90 积分 最后运行结果:代码:#incl ...

最新文章

  1. eclipse编辑窗口不见了(打开左边的java、xml文件,中间不会显示代码)
  2. XtraGrid GridView设置默认选中的行颜色
  3. 【 FPGA 】设置输出延迟(Output Delay)
  4. mysql orm .net,2020年 .NET ORM 完整比较、助力选择
  5. 天津春考计算机重点知识,天津春考第一学期期中试卷(计算机基础)
  6. html 设置 下拉列表 不可用
  7. web.xml与index.html
  8. 【OCR技术】大批量生成文字训练集
  9. 深入理解 Python 异步编程(上)
  10. C语言--输入一个数判断是否为素数(多种方法)
  11. 基于STM32制作万能遥控器---1
  12. matlab中数据导入及处理,matlab 和 excel 数据的导入导出
  13. MAC jd-gui 安装
  14. 踩坑记6 vue3、生命周期钩子、vue-devtools beta
  15. linux boot引导修复工具,修复linux的grub2引导(单独/boot,lvm-root)
  16. Linux下发送邮件
  17. java中string中转义_如何在String.Format中转义%?
  18. 安全科普:使用Cookie会导致哪些安全问题?
  19. 独乐乐不如众乐乐,这三款国产优质软件,你值得拥有
  20. 科学知识图谱绘制方法、步骤及工具

热门文章

  1. android 4.3低吗,Android 4.3两新特征曝光:低电耗蓝牙功能
  2. 川大研究生计算机专业有哪些,问问川大计算机研究生招收的小专业有哪些
  3. 在ZendStudio中增加新的PHP模板
  4. 中国锂离子电池市场现状研究分析与发展前景预测报告
  5. 零配置自动开局——Zero Touch Provisioning
  6. onsubmit事件
  7. SQL/Oracle——第六章 PL/SQL函数(作业3)
  8. SAP ABAP 学习总结(1):初始SAP ABAP
  9. Alian解读SpringBoot 2.6.0 源码(一):SpringApplication对象创建(Spring工厂加载机制)
  10. 案例:中科润泽鞋业专用ERP(CRS-ERP)在东艺鞋业的成功实施(转)