您的位置:首页 > 理论基础

一 计算机科学基础 1.1数制及转换

2018-01-06 23:11 274 查看
基本概念:

^ = 介乘

2^4 = 二的四次方

2^-4 = 二的负四次方,也就是1/16,十六分之一

位 = 整数部分个位为0位,十位为1位,百位为2位,小数点后面第一位为-1位,其他位同理

 二进制转换各个进制 :

// 分解求和法

 2 --> 10 :  100110.101B = 2^5+2^2+2^1+(2^-1+2^-3) = 32+4+2+(1/2+1/8) = 38+5/8 = 38.625D

// 421法

 2 --> 8   :  10101111.10111B = 010 101 111 . 101 110B = 2 5 7 . 5 6 = 257.56O

// 8421法

 2 --> 16 :  10101111.10111B = 1010 1111. 1011 1000B = 10 15 . 11 8 = A F . B 8 = AF.B8H

各个进制转换成二进制 :

//整数部分除二取余,最后倒取,小数部分乘二取整(整数部分),最后正取

10 --> 2 :  38.625D = 38 % 2 = 0     = 0.625 * 2 = 1.250   最终结果整数倒取,小数正取 = 100110.101B

                             = 19 % 2 = 1     = 0.250 * 2 = 0.5

                             =  9  % 2 = 1     = 0.500 * 2 = 1

                             =  4  % 2 = 0

                             =  2  % 2 = 0

                             =  1  % 2 = 1    

//使用421法逆运算及可,小数部分也一样

 8  --> 2 :   257.56O = (2 = 010) (5 = 101) (7 = 111).(5 = 101) (6 = 110) = 10101111.10111B

//同八到二一样,但算法使用8421法

16 --> 2 :   AF.B8H = (A = 1010) (F = 1111).(B = 1011) (8 = 1000) = 10101111.10111B

 

其实我们知道以上这些就可以了,可以于2进制为通用进制,来进行各个进制之间的转换,但再多学一点也好,下面我们来看下10进制到16进制和10进制到8进制之见的转换吧.

其实道理很简单,十转二的时候是用除二取余的办法,那么16进制就是除16取余,8进制是除8取余数,小数部分乘8或16取整.

10 --> 8 :  38.625D = 38 % 8 = 6   = 0.625 * 8 = 5     最终结果整数部分倒取,小数部分正取 = 46.5O

                             =  4  % 8 = 4 

10 --> 16 : 38.625D = 38 % 16 = 6  = 0.652 * 16 = 10 最终结果整数部分倒取,小数部分正取 = 26.AH

                                = 2 % 16 = 2

反或来进行各个位到10进制也是和二进制一个道理  只不过位的权 不一样了~ 二进制是2,16进制是16,8进制是8.

 8  --> 10 : 46.5O = 4*8^1 + 6*8^0 + 5*8^-1 = 32 + 6 + 5/8 = 38.625D

16 --> 10 : 26.AO = 2*16^1 + 6*16^0 + 10(A) * 16^-1 = 32 + 6 + 10/16 = 38.625

OK 清晰的理解上面的转换规则,遇到数制转换也就不会再有问题了.

 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: