计算机各种进制之间的转换,外行人也能看的懂

目录

一、进位计数制

 二、计算机中常用的几种进制

 三、进位计数制相互转换

1、二进制转八进制

2、二进制转十进制

 3、二进制转十六进制

4、八进制转二进制

5、八进制转十进制

 6、八进制转十六进制

7、十进制转成 n (n=2,8,16)进制数

8、十六进制转二进制

8、十六进制转八进制

9、十六进制转十进制

四、总结:


一、进位计数制

所谓进位计数制也称计数制,是指用一组固定的符号和统一的规则来表示数值https://baike.baidu.com/item/%E6%95%B0%E5%80%BC的方法。按进位的方法进行计数,称为进位计数制。在计算机中采用的是主要是二进制,此外还有八进制、十进制、十六进制的表示方法。在日常生活中,我们最常用的是十进位计数制,即按照逢十进一的原则进行计数的。

下面先带大家了解一下进制中的基本概念。


一种进位计数制包含一组数码符号三个基本因素

数码:一组用来表示某种数制的符号。例如,二进制的数码是0、1 ;八进制的数码是0、1、2、3、4、5、6、7;十进制的数码是0、1、2、3、4、5、6、7、8、9;十六进制的数码是0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F。

* 基数(R):某种数制可以使用的数码个数。例如,二进制的基数是2,八进制的基数是8;十进制的基数是10; 十六进制的基数是16。

*数位(i):数码在一个数中所处的位置,以小数点为中心,小数点左边位数,从右向左依次从0开始,小数点右边位数从左向右依次从-1开始。例如十进制数543.21的每个数字所在位数为

* R^{i}):权是基数(R)的数位(i)次方,表示数码在不同位置上的数值。例如:十进制数值543.21 各位数的权分别为 10^{2}10^{1}10^{0}10^{-1}10^{-2}

* 加权计算各位项的合计值为结果值k_{i}R^{i}):k_{i} 表示第 i 位的数字。任意进位数的值都可以写为按权展开的多项式的合计。例如 543.21 =  5*10^{2}+4*10^{1}+3*10^{0}+2*10^{-1}+1*10^{-2}

注:负次方=正次方的倒数,比如10^{-1}=1/10^{1}

 二、计算机中常用的几种进制

计算机中常用的几种进制,二进制(B)、八进制(O)、十进制(D|不写区分符)、十六进制(H),几进制那么它的基数就是几。

 三、进位计数制相互转换

在线进制转换OSCHINA.NET在线工具,ostools为开发设计人员提供在线工具,提供jsbin在线 CSS、JS 调试,在线 Java API文档,在线 PHP API文档,在线 Node.js API文档,Less CSS编译器,MarkDown编译器等其他在线工具https://tool.oschina.net/hexconvert这里附上在线进制转换工具,方便大家自我练习时验证计算结果是否正确。


1、二进制转八进制

转换规则:以小数点为中心,整数部分从右向左,小数部分从左向右,"三位一体",不足补0。

思路:先按照3位一体分隔,不足位补0,每3位代表一个值,计算时,每3位从右向左位次为0,1,2

10101010.1111_{B} =010 101 010.111 100 _{O} = 252.74​​​​​​​

 做个小练习 比如:二进制数 111101.0110 转为8 进制为多少呢?

2、二进制转十进制

转换规则:二进制各位上的系数*对应的权,然后求其和。

例如:二进制111.11转为十进制数,结果为7.75

 3、二进制转十六进制

转换规则:以小数点为中心,整数部分从右向左,小数部分从左向右,"四位一体",不足补0。

 例如:二进制数,101010101.111 转换为 16进制为 155.E 

注:上面图例中小数点后的 1110 四位计算过程写错了,应该是从右向左计算,下图纠正的计算过程

 注:在十六进制中,只有0~9,A~F 数位。A~F 与 十进制中 10~15 等同。

4、八进制转二进制

转换规则与二进制转八进制正好相反,把八进制上的每一位数一分为三,即为二进制数。

例如:765.43 转为 二进制为 111 110 101 . 100 011

首先八进制数只有0~7 ,那么二进制跟八进制的对应关系表如下,记住即可。

二进制八进制
0000
0011
0102
0113
1004
1015
1106
1117

5、八进制转十进制

转换规则:八进制各位数上的系数*权,再求和。

例如:123.13 转为十进制就是 83.171875

 6、八进制转十六进制

转换规则1:先把八进制转成十进制,再把十进制转成十六进制。

转换规则2:先把八进制转成二进制,再把二进制转成十六进制。

例如:八进制数77.77 ,先转成二进制为 111 111.111 111,再转为16进制,此处二进制转16进制为4位一体的分隔规则,为0011 1111. 1111 1100,那么计算为16进制,结果就是 3F.FC。

7、十进制转成 n (n=2,8,16)进制数

转换规则:整数部分除以 n 取余数,倒着写。

                  小数部分乘以 n 取整数,顺着写。小数部分一般保留三位,末位四舍五入。

例如:十进制数18.55 转十六进制数,结果为:12.852(H)

这里我个人觉得必须掌握十进制转二进制方法。

例如:十进制数18.75 (D)转为二进制数为 10010.11(B)

整数位计算方式: 整数位除以2 取余数直到商为0,那么按照上面计算过程得到的余数,从上到下依次对应二进制整数位的从右到左顺序的值 10010。

0.75*2 = 1.5 取整数 1 对应二进制位小数点后第一位

0.5*2 = 1.0 取整数1 对应二进制位小数点后第二位

小数位计算方式:小数乘以2 取整数位直到所得结果为整数停止,正序对应二进制数位的从左到右顺序的值11

8、十六进制转二进制

转换规则:把十六进制每一位数,一分为四,即可得到二进制数。

例如:十六进制 FEC.BA 转为 二进制为 1111 1110 1100.1011 1010

十六进制二进制
00000
10001
20010
30011
40100
50101
60110
70111
81000
91001
A1010
B1011
C1100
D1101
E1110
F1111

8、十六进制转八进制

转换规则:

先从十六转十进制,再转为八进制

或者

十六转为二进制,再转为八进制

9、十六进制转十进制

转换规则:让十六进制上的各位系数乘以对应的权,然后求和即为十进制数值。

例如:十六进制的 12F.C  转为 十进制 就是 303.75

计算过程如下

 个人感觉,最主要需要掌握 二进制 和十进制 之间的转换是最基础的。

四、总结:

  • n 进制转 十进制的规则 小数点左侧(系数*n的位次方+系数*n的负位次方)。

注:n进制转十进制时,小数点左侧按照从右向左位次依次为0,1,2...;小数点右侧按照从左到右位次依次为-1,-2,...。

  • 二进制转八进制,三位一体分隔;反过来,八进制转二进制,一分为三。

注:二进制转为八进制或十六进制,分割后,计算时,按照从右向左位次,依次为0,1,2

  • 二进制转十六进制,四位一体分隔;反过来,十六进制转二进制,一分为四。
  •  十进制转二进制,整数部分除以2,取余数,一直到商为0。每次得到的余数按倒序从右向左依次就是二进制小数点左侧的数值。小数部分*2,每次取整数位,直到乘2结果为整数,每次得到的整数位正序从左向右依次就是二进制小数点右侧的数值。
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

跟着飞哥学编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值