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

本篇博文主要讲解在编程之中,用到的进制转换的方法和逻辑,毕竟在计算机语言中,最原始的底层进制都是二进制,所以在开发中,在所难免会遇到项目功能需要去相应的转换。

分析具体如下:

2进制  只有0和1组成          如:010101
8进制  以0开头,0~7组成        如:012345
10进制 以1~9开头,0~9组成        如:100
16进制 以0X开头,0~9或者a~f组成   如:0x12c

一:进制的概念

  • 进制也就是进制位,我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。

二:十进制转二进制

  • 方法为:十进制数除2取余法,即十进制数除2,余数为权位上的数,得到的商值继续除2,依此步骤继续向下运算直到商为0为止。

三:二进制转十进制

  • 方法为:把二进制数按权展开、相加即得十进制数。
  • 进制数第1位的权值是2的0次方,第2位的权值是2的1次方,第2位的权值是2的2次方。。。。。公式:第N位*2的N-1次方
  • 11010 = 1×24 + 1×23 + 0×22 + 1×21 + 0×20 = 26(十进制)

四:二进制转八进制

  • 方法为:3位二进制数按权展开相加得到1位八进制数。(注意事项,3位二进制转成八进制是从右到左开始转换,不足时补0)。

五:八进制转二进制

  • 方法为:八进制数通过除2取余法,得到二进制数,对每个八进制为3个二进制,不足时在最左边补零。

六:二进制转十六进制

  • 方法为:与二进制转八进制方法近似,八进制是取三合一,十六进制是取四合一。(注意事项,4位二进制转成十六进制是从右到左开始转换,不足时补0)。

七:十六进制转二进制

  • 方法为:十六进制数通过除2取余法,得到二进制数,对每个十六进制为4个二进制,不足时在最左边补零。

八:十进制转八进制或十六进制

  • 间接法—把十进制转成二进制,然后再由二进制转成八进制或者十六进制。
  • 将十进制转换为其它进制时比较复杂,整数部分和小数部分的算法不一样,下面我们分别讲解。
    1. 整数部分
      十进制整数转换为 N 进制整数采用“除 N 取余,逆序排列”法。具体做法是:
      将 N 作为除数,用十进制整数除以 N,可以得到一个商和余数;
      保留余数,用商继续除以 N,又得到一个新的商和余数;
      仍然保留余数,用商继续除以 N,还会得到一个新的商和余数;
      ……
      如此反复进行,每次都保留余数,用商接着除以 N,直到商为 0 时为止。

把先得到的余数作为 N 进制数的低位数字,后得到的余数作为 N 进制数的高位数字,依次排列起来,就得到了 N 进制数字。

    1. 小数部分
      十进制小数转换成 N 进制小数采用“乘 N 取整,顺序排列”法。具体做法是:
      用 N 乘以十进制小数,可以得到一个积,这个积包含了整数部分和小数部分;
      将积的整数部分取出,再用 N 乘以余下的小数部分,又得到一个新的积;
      再将积的整数部分取出,继续用 N 乘以余下的小数部分;
      ……
      如此反复进行,每次都取出整数部分,用 N 接着乘以小数部分,直到积中的小数部分为 0,或者达到所要求的精度为止。

把取出的整数部分按顺序排列起来,先取出的整数作为 N 进制小数的高位数字,后取出的整数作为低位数字,这样就得到了 N 进制小数。

1.如果一个数字既包含了整数部分又包含了小数部分,那么将整数部分和小数部分开,分别按照上面的方法完成转换,然后再合并在一起即可。例如:
十进制数字 36926.930908203125 转换成八进制的结果为 110076.7345;
十进制数字 42.6875 转换成二进制的结果为 101010.1011。

2:注意,十进制小数转换成其他进制小数时,结果有可能是一个无限位的小数。请看下面的例子:
十进制 0.51 对应的二进制为 0.100000101000111101011100001010001111010111…,是一个循环小数;
十进制 0.72 对应的二进制为 0.1011100001010001111010111000010100011110…,是一个循环小数;
十进制 0.625 对应的二进制为 0.101,是一个有限小数。

嗯,本章节主要阐述这些,二进制,八进制,十进制,十六进制的转换,基本都大同小异,重点就是理解清楚,十进制转换是按照三组划分的,而十六进制转换是按照四组数字进行划分的,
如:二进制:0101 0101 转为16进制为55;(十六进制转换)
如: 二进制:101 010 101 转为10进制的85;(十进制)

其次就是逻辑次方的算法,每次往后递增1,进制是从右往左开始算,OK,就讲解到此,若还有疑问可以留言!谢谢~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值