`
在水伊方
  • 浏览: 107525 次
  • 性别: Icon_minigender_1
  • 来自: 福州
社区版块
存档分类
最新评论

进制转换

    博客分类:
  • Java
 
阅读更多

十进制-->二进制

 

原理:1、将被除数除以2,得到商与余数,并记录下余数

           2、如果所得商为0,则运算停止,并将所得余数倒序排列,即为转换后结果,否则将商当做被除数继续1,2步骤

 

例子:十进制6转换成二进制

1、6/2=3,商为3,余数为0

2、商不为0,则现在3为被除数,有3/2=1...1,商为1,余数为1

3、商不为0,现在1变成了被除数,则有1/2=0...1,商为0,余数为1

4、商为0,运算停止,将所有余数倒序排列为110,所以十进制6的二进制表示为110

用表格表示即为

 

二进制-->十进制

 

2进制转为10进制相对较为简单些,先来看一下10进制123的值是如何计算出来的,我们都知道10进制是逢10进一(10也称为权数),所以个位上的1(1也称为基数)就是表示1,即1*10^0,十位数上的1表示10,即1*10^1,以此类推,2进制是以2为权数的,所以要将2进制转为10进制的方法与上面讲的计算10进制的方法类似,只是此时的权术变为2了

 

例子:二进制110转为十进制是多少

1*2^2+1*2^1+0*2^0=4+2+0=6,因为0乘以任何数都为0,所以我们遇到基数为0的时候,可以略过

 

十进制-->八进制(用0开头表示)

10进制转为8进制的方法与10进制转为2进制的方法类似,只是除数由2变为了8,下面看一下10进制520如何表示为8进制,表格表示形式如下:

所以520表示为八进制为1010


八进制-->十进制

8进制转为10进制与2进制转为10进制的方法类似,只是把权数变为了8,例如1010转为10进制,过程为

1*8^3+2*8^1=520

 

十进制-->十六进制(用0x开头表示)

10进制转为16进制的方法与10进制转为2进制的方法类似,只是除数由2变为了16,下面看一些520如何表示为16进制,表格表示形式如下:

十六进制-->十进制

16进制转为10进制与2进制转为10进制的方法类似,只是把权数变为了16,但是16进制是以16为单位的,

我们只有0~9这10个数字,所以用A、B、C、D、E、F来表示10、11、12、13、14、15。下面我们看一下5A如何转换为10进制的,算是为5*16^1+10=90

 

二进制-->八进制

从后往前每三位为一组,缺位的用0填补,然后按照10进制的方法进行转换,如101100转换过程如下

101转为10进制为5,

100转为10进制为4

则101100转为八进制为54

 

八进制-->二进制

从后往前每一位按照10进制转为三位2进制,缺位的用0填补,则8进制的54转为2进制过程如下

5转为2进制为101

4转为2进制为100

所以54转为2进制为101100

 

十六进制<-->二进制

十六进制和二进制的互转与八进制和二进制的互转类似,只是此时应以4位为一组。如11111011转为16进制过程为

1111转为16进制为F

1101转为16进制为D

所以11111101转为16进制为FD,如果要求FD转为2进制,则方法与八进制的相同,把一位16进制数表示为4位2进制数,F转为1111,D则转为1101

 

负数的进制

负数的进制与正数的进制略有不同,需要先求其补码,例如要求-6的二进制

由于整型占4个字节,所有6在计算机中表现形式为0000-0000 0000-0000 0000-0000 0000-0110

求其反码,按位取相反数1111-1111 1111-1111 1111-1111 1111-1001

然后再将反码加1为1111-1111 1111-1111 1111-1111 1111-1010,这即为-6的二进制的表现形式,然后再按照二进制转为其他进制的方法进行相应进制转换。

 

注:以上进制间的转换全部针对整数 

  • 大小: 18.1 KB
  • 大小: 3.2 KB
  • 大小: 4 KB
  • 大小: 3.6 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics