首先,先明确进制中的两个基本概念。

基:二进制的基为二,八进制的基为八,十进制的基为十,十六进制的基为十六,以此类推。

位权:以小数点开始,依次向左右两边编号,向左为0,1,2,…,向右为-1,-2,-3,…。以二进制为例,从小数点开始,向左位权依次       为202122,向右依次为2-12-2,其他进制以此类推。

二进制,八进制,十六进制转换为十进制:按权相加法,即将该进制数的每一位乘以位权,然后相加,和即为该进制对应的十         ,进制。例如:

       10101002=1*26+1*24+1*22=84

       FFFF(16)=F*163+F*162+F*161+F*160=65535

十进制转换成其他进制:

      1. 整数部分:除基取余法,即用目标数制的基数去除十进制数,取余,将所得商再除以基数,直到商为“0”,所得余数逆序即为该数的目标进制。

      2. 小数部分:乘基取整法,即小数部分乘以目标数制的基数,取整,将其小数部分再乘基数,直到小数部分为“0”,或满足要求的精度为止。(通常情况下都是算出满足要求的精度)。

       例如:12.75(2)=1100.11

二进制转换成八进制:三位一体法,以小数点开始,向左右两边每三位一组,不足的话,在整数部分最高位前以及小数部分最         低位后补"0",即表现为该进制数首尾补零至小数点两边的位数都是三的倍数(注意无需补冗余的"0")。

       例如:11.0100111(2)=011.010011100(2)=3.234(8)

二进制转换为十六进制:四位一体法,以小数点开始,向左右两边每四位一组,不足的话,在整数部分最高位前以及小数部分         最低位后补"0",即表现为该进制数首尾补零至小数点两边的位数都是四的倍数(注意无需补冗余的"0")。

       例如:110.111010(2)=0110.11101000(2)=6.E8(16)

八进制转换成二进制:取一分三法,即将该进制数的每个位上的数看成是一个(一位)十进制数,除二取余转换成一个三位二进         制数,顺序即是。

       例如:62.54(8)=6,2,.5,4(10)=110,010,.101,100(2)=110010.101100(2)=110010.1011(2)

十六进制转换成二进制:取一分四法即将该进制数的每个位上的数看成是一个(一位)十进制数,除二取余转换成一个四位二         进制数,顺序即是。

       例如:1E.23(16)=1,E,.2,3(16)=0001,1110,.0010,0011(2)=00011110.00100011(2)=11110.00100011(2)

八进制转换成十六进制或十六进制转换成八进制:间接法,以二进制为媒介,将八进制(十六进制)转换成二进制,再由二进         制转换成十六进制(八进制)。

下面我们来考虑负数时的情形。由于任何数在内存中都是以二进制补码形式存在的,而正数的补码等于原码,负数的补码是其          对应的正数的反码加一。举例说明,如将-152(10)转换成八进制,-152(10)=

       -152

       对应的正数:152,二进制原码:10011000,反码:01100111,反码加一:01101000

       即-152的二进制表示为01101000(2),采用三位一体法,得其对应的八进制为150(8)。