进制转换(二进制、八进制、十进制、十六进制)涵盖整数与小数部分,超详细_243h转8q等于几-程序员宅基地

技术标签: 算法  c语言  基础知识  

今天来总结一下各种进制转换问题,详细齐全易于理解,希望对你有帮助哦!


先从我们最熟悉的十进制入手吧,其他进制与十进制的转换方法都是一样的,保证能全部记住!

整型有4种进制形式:

  1. 十进制:由0-9数字组成,不能以0开头。
  2. 二进制:由0和1两个数字组成。
  3. 八进制:由0-7数字组成,为了与其他进制的数字进行区分,通常开头以0作为标记表示八进制。
  4. 十六进制:由0-9和A-F组成。为了与其他进制的数字进行区分,通常开头以0x作为标记表示十六进制。

先来贴一张进制转换表:
在这里插入图片描述

一、十进制转换为二进制、八进制、十六进制

整数转换

1、十进制转二进制

除2取余倒序输出
(1)十进制转二进制的转换原理:除以2,反向取余数,直到商为0终止

(2)具体做法:
将某个十进制数除2得到的整数部分保留,作为第二次除2时的被除数,得到的余数依次记下,重复上述步骤,直到整数部分为0就结束,将所有得到的余数最终逆序输出,则为该十进制对应的二进制数。

例1:9(十进制)→1001(二进制)

在这里插入图片描述
最终得到: 9(10)=1001(2)

例2:42(十进制)→101010(二进制)

在这里插入图片描述
最终得到: 42(10)=101010(2)

2、十进制转八进制

除8取余倒序输出
(1)转换原理:除以8,反向取余数,直到商为0终止。

(2)具体步骤与二进制一样
例:796(十进制)→1434(八进制)

将796除8得到第一个余数为4,将整数部分99作为第二次的被除数,重复上述步骤,直至最终整数部分为0就结束。将得到的所有余数逆序输出
在这里插入图片描述
最终得到: 796(10)=1434(8)

3、十进制转十六进制

除16取余倒序输出
(1)转换原理:除以16,反向取余数,直到商为0终止。

(2)具体步骤也和二进制、八进制一样,重复上述做法即可得到十六进制数。

例如: 十进制数796转换为十六进制数
最终得到: 796(10)=31C(16)
在这里插入图片描述

注意: 十六进制数是由0-9和A-F(或者a-f)组成的,A相当于十进制中的10,B相当于11,依次类推,F相当与15,上述例子中取得的余数12即为十六进制中的C

总结:以上几种进制的整数部分转换原理都是除以进制数,将得到的余数倒序输出

小数部分转换

贴一张小数部分进制表
在这里插入图片描述

1、十进制转二进制

(1) 原理: 十进制小数转换成二进制小数采用 乘2取整,顺序输出

注:这里用首字母D表示十进制,B表示二进制

例1: 0.68D = ______ B(精确到小数点后5位)
如下所示,0.68乘以2取整,然后再将小数部分乘以2取整,重复上述操作。若小数部分始终不为0,则达到题目要求精度即可。得到二进制结果为:0.10101B.

具体步骤:
0.68x2=1.36 -->1
0.36x2=0.72 -->0
0.72x2=1.44 -->1
0.44x2=0.88–>0
0.88x2=1.76 -->1 已经达到了题目要求的精度,最后将得到的整数部分顺序输出即可
最终为:0.68D–>0.10101B

例2: 78.6875 D = ______ B
这个例子既包含整数部分又包含小数部分,则分开计算。整数部分根据 “除2取余倒叙输出” 得到该部分结果,小数部分根据 “乘2取整顺序输出” 得到小数部分结果。

具体步骤:
(1) 整数部分:
78/2=39–>0
39/2=19–>1
19/2=9–>1
9/2=4–>1
4/2=2–>0
2/2=1–>0
1/2=0–>1
将得到的余数倒序输出,得到十进制转二进制整数部分结果为:1001110
(2) 小数部分:
0.6875x2=1.375–>1
0.375x2=0.75–>0
0.75x2=1.5–>1
0.5x2=1.0–>1
0.0x2=0.0–>0(小数部分结果已经为0,结束)
将得到的余数正序输出,得到十进制转二进制小数部分结果:10110
最终结果为:78.6875 D = 1001110.10110 B

在这里插入图片描述

2、十进制转八进制

(1)原理:十进制小数转换成八进制小数采用 “乘8取整,顺序输出”
(2)思路和十进制转二进制一样,参考如下例题:

注:通常用首字母D表示十进制,O表示八进制

例1: 10.68D = ______ O(精确到小数点后3位)
与二进制类似,这个例子既包含整数部分又包含小数部分,则分开计算。整数部分根据 “除8取余倒叙输出” 得到该部分结果,小数部分根据 “乘8取整顺序输出” 得到小数部分结果。

具体步骤:
(1) 整数部分
10/8=1 -->2
1/8=0 -->1
将得到的余数倒序输出,得到十进制转八进制整数部分结果为:12
(2) 小数部分
0.68* 8=5.44 -->5
0.44* 8=3.52 -->3
0.52* 8=4.16 -->4 已经达到了题目要求的精度,即可结束
将得到的余数正序输出,得到十进制转八进制小数部分结果:534
最终结果为: 10.68D = 12.534 O

3、十进制转十六进制

(1)原理:十进制小数转换成十六进制小数采用 “乘16取整,顺序输出”
(2)思路也是一样的,就不重复了

注:这里用首字母D表示十进制,H表示十六进制
例题: 25.68D = ______ H(精确到小数点后3位)

整数部分除以16取余数,直到无法整除。小数部分0.68乘以16,取整,然后再将小数乘以16,继续取整,直到结果为0或者达到题目要求精度终止。得到结果:19.ae1H.
(1) 整数部分
25/16=1 -->9
1/16=0 -->1
倒序输出为:19
(2) 小数部分
0.68* 16=10.88 -->a(即十进制中的10)
0.88* 16=14.08 -->e
0.08* 16=1.28 -->1
已经达到了要求的精度,顺序输出为:ae1
最终结果为:25.68D = 19.ae1 H

总结:小数部分转换原理都是乘以进制数取整数部分,最后将整数部分顺序输出。

二、 二进制、八进制、十六进制转换为十进制

整数转换

1、全部总结如下:
在这里插入图片描述

2、三者转换原理都是一样的

在这里插入图片描述

小数部分转换

1、二进制转十进制

(1)原理:整数部分按上述进行操作即可,小数部分从小数点后一位指数为-1开始算起,之后依次为-2、-3……
(2)具体运用和步骤举例说明:

在这里插入图片描述

2、八进制转十进制

(1)原理:整数部分操作以及运算不变,小数部分同二进制类似,将2变为8即可
(2)具体步骤方法如下:

例如:八进制数 72.45 转换成十进制数
(1) 整数部分:
7* 8^1+ 2* 8 ^0=58
(2) 小数部分
4* 8^(-1) + 5* 8^(-2)=0.5+0.078125=0.578125
最终为:72.45 O = 58.578125 D

3、十六进制转十进制

(1)原理:整数部分操作以及运算不变,小数部分同以上操作类似,将进制数换成16即可
(2)具体方法步骤如下:

例题:(1A6.3B8) H= ______ D

计算结果为:
1A6.3B8=1* 16^2+A* 16 ^1+6* 16 ^0 +3* 16 ^(-1)+B* 16 ^(-2)+8* 16 ^(-3) =422.232422

总结:以上二进制、八进制、十六进制转换为十进制当中的整数部分从右往左指数从0开始递增,小数部分从左往右从-1开始递减,个位指数为0。原理都是一样的,计算结果均为:对应数字 x 进制数的指数幂,最后进行累加求和即可。

三、 二进制转换成八进制数、十六进制数

1、二进制转换成八进制
原理:“三合一” 取二进制数中的三位合为八进制数的一位

2、二进制转换成十六进制
原理:“四合一” 取二进制数中的四位合为十六进制数的一位

例1:1010 0100 B = 244 Q
在这里插入图片描述
例2:1010 0100 B = a4 H
在这里插入图片描述

再来贴个例子:

在这里插入图片描述

四、八进制、十六进制转换成二进制

1、八进制数转换成二进制
原理:八进制数的一位是二进制数的三位

2、十六进制数转换成二进制
原理:十六进制数的一位是二进制数的四位

在这里插入图片描述

五、八进制与十六进制之间的转换

这两者之间的转换可以借助十进制或者二进制完成,可以先将八进制转换成十进制或二进制,再转换成十六进制,两者可以通过间接转换来实现。

以上就是所有常用进制转换,包括整数部分和小数部分,已经是很详细了,个人觉得通过例子来理解是最好的方法,记住进制转换的一些原理和规律,换成其他进制也是一样的用。关于进制转换问题是比较基础的,所以一定要掌握哦!

希望我的文章对你有所帮助,嘻嘻!若有错误的地方还望大家批评指正,谢谢大家阅读!
在这里插入图片描述

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/DJL0718/article/details/107797847

智能推荐

Viper炫彩蛇的下载与安装(MSF图形化界面)_简易极速安装版-程序员宅基地

文章浏览阅读647次,点赞2次,收藏2次。1.更新apt-get2.下载docker.ioY。_炫彩蛇

CVPR2021|| Coordinate Attention注意力机制_位置注意力机制-程序员宅基地

文章浏览阅读2.4w次,点赞63次,收藏418次。Paper:https://arxiv.org/pdf/2103.02907.pdfGitHub:https://github.com/Andrew-Qibin/CoordAttention轻量,优秀,好用!讲之前我们先回顾一下以前的SE与CBAMSESE比较简单,看一下结构图差不多就能理解了,如果有些实现不太懂的,可以借鉴一下CBAM的。但SE只考虑内部通道信息而忽略了位置信息的重要性,而视觉中目标的空间结构是很重要的。CBAM稍微介绍一下CBAM,如图b所示,CBAM包含空间注意力和通_位置注意力机制

eslint搭配prettier使用步骤_plugin:prettier/recommended-程序员宅基地

文章浏览阅读1.2k次。这里的执行逻辑顺序是:eslint会首先读extends的规则,这个时候遇到了最后配置的plugin:prettier/recommended,而这个插件又会先读本地配置的.prettierrc文件再读取prettier自己内部设置的配置,最后读.eslintrc.json的rules配置。2、其次配置.eslintrc.json文件,extends: [“plugin:prettier/recommended”],如果有其他扩展,则"plugin:prettier/recommended"放在最后。_plugin:prettier/recommended

kettle 共享数据库连接时带汉字引发的错误-程序员宅基地

文章浏览阅读548次。处理方式:在目录: C:\Users\Administrator\.kettle 里 找到:shared.xml 把该文件的编码方式改为UTF-8,重启kettle就没问题了

weka up-sampling & down-sampling-程序员宅基地

文章浏览阅读532次。[b]up-sampling:[/b]SMOTE algorithm,over-sampled by creating ``synthetic'' examples rather than by over-sampling with replacement.[b]Weka supervised SMOTE filter [/b]两个参数: [list][*]neares..._weka oversampled

php中如何得到js中的变量,javascript-js变量在PHP中怎么获取该变量?-程序员宅基地

文章浏览阅读1.3k次。在js中定义一个变量,在PHP中怎么获取该变量?(在一个页面)回复内容:在js中定义一个变量,在PHP中怎么获取该变量?(在一个页面)JS是前端,PHP是后端,后端PHP要获取前端JS的变量,那前端JS可以通过AJAX传输数据给后端PHP.比如登录页面login.php:js中通过post提交到后台:var data = {'param' : xxx};$.post(url,data,callba..._php 获取js中变量

随便推点

Qt 中 Q_OBJECT 宏及 moc_*.cpp文件_moc_cpp-程序员宅基地

文章浏览阅读2.1k次,点赞4次,收藏28次。Qt 中 Q_OBJECT 宏及 moc_前缀文件Q_OBJECT 宏元对象系统 (Meta-Object System)了解 Q_OBJECT 宏展开 Q_OBJECT 宏MOC 预编译器MOC (Meta-Object Compiler)前缀 moc_xx.cpp文件代码示例如下MakeFile文件生成的moc文件如下==moc_whatismoc.cpp== 文件分析片段一结构体`qt_meta_stringdata_WhatIsMoc_t`片段二宏`QT_MOC_LITERAL`和`qt_meta__moc_cpp

WoWoViewPager 炫酷啊!-程序员宅基地

文章浏览阅读1k次。WoWoViewPager WoWo可以优化你的App介绍/引导页面,制作你的App简历。WoWo将动画和viewpager结合起来。当你滑动viewpager的时候,你也在控制动画的当前帧。就好像控制动画时间一般。比如上面的两个Gif,是先向前滑动然后向后滑动。目录English READMEGradle备注Demo版本Todo_wowoviewpager

干货福利:CVPR2016代码合集_yeonwoonya-程序员宅基地

文章浏览阅读4.3k次。DoReFa-Net: Training Low Bitwidth Convolutional Neural Networks with Low Bitwidth Gradients:https://github.com/ppwwyyxx/tensorpack/tree/master/examples/DoReFa-NetCode for Stacked attention network_yeonwoonya

深度优先搜索(DFS)和广度优先搜索(BFS)_深度优先搜索是基于中序遍历吗-程序员宅基地

文章浏览阅读537次。深度优先搜索和广度优先搜索,都是图形搜索算法。一、深度优先搜索(DFS) 深度优先搜素,是针对图和树的遍历算法,利用深度优先搜索算法可以产生目标图的相应拓扑排序表,利用拓扑排序表可以方便的解决很多相关的图论问题,如最大路径问题等等。 一般会使用栈数据结构来辅助实现DFS算法。 DFS主要思路就是从图中一个未访问的顶点V开始,沿着一条路一直往下走到底,然后从这条路尽头的结点回退到上一个节点,再从另一条路开始走到底.....,不断递归重复..._深度优先搜索是基于中序遍历吗

编译OpenWRT LEDE 固件的一些说明_generic-squashfs-combined-程序员宅基地

文章浏览阅读1.6w次,点赞4次,收藏22次。Github Actions 云编译 OpenWRT LEDE 固件固件文件说明文件共提供多种类型供下载(根据编译时选择的Target Images配置),需要其他类型的请自行转换,下面是部分说明序号名称说明(1)openwrt-x86-64-generic-squashfs-combined.img 或.gz带引导分区文件,也就是刷完后可以直接启动无需做设置,推荐使用!(2)openwrt-x86-64-generic-squashfs-combined.vmdk_generic-squashfs-combined

NOI Online Round 3 PJ 游记_noi online游记3-程序员宅基地

文章浏览阅读257次。博客园同步Day rand()\text{Day rand()}Day rand()报上了名。Day 0\text{Day 0}Day 0期中考试考萎了,彻底萎了,心里什么也不想了。试机?试个啥机?Day 1\text{Day 1}Day 1下午老妈说作业太多,于是我 16:4716:4716:47 匆匆开启了电脑。测试冥间数据,发现 tg180\text{tg} 180tg180 还可以,不错!17:0017:0017:00 开_noi online游记3

推荐文章

热门文章

相关标签