一、进位计数制的基本概念

将数字符号按排列成数位,并遵照某种由低到高的进位方式计数表述数值的方法,称为计数制。

1.十进制

十进制计数由0,1,2,3,4,5,6,7,8,9共10个数字符号组成。相同数字符号在不同的数位上表示不同的数值,每个数位计满十就向高位进一 ,即“逢十进一”

2.八进制

“逢八进一”

3.二进制

“逢二进一”

4.十六进制

1,2,3,4,5,6,7,8,9,A,B,C,D,E,F

5.基数和权

 K2K1K0小数点K-1K-2
J=222=421=220=1 2-1=0.52-2=0.25
J=882=6481=880=1 8-1=0.1258-2=0.015625
J=10102=100101=10100=1 10-1=0.110-2=0.01
J=16162=256161=16160=1 16-1=0.062516-2=0.00390625
二、数制之间的转换

计算机内部使用的数字符号只有0和1两个。也就是说,计算机内部使用的是二进制数,所有数值数据和非数值数据,都是有0和1这两个数字符号加以组合而成的,我们称之为“二进制代码”。

为了方便期间,常在数字后面加一个缩写字母后缀作为不同进制的数标识,各种进制数的后缀字母:

       B:二进制        O:八进制

       D:十进制     H:十六进制

    对于十进制,通常不加后缀,

1.二进制与十进制的转换

(1)二进制转十进制

方法1:按权展开法 例如 :  (1011.01)2

K3K2K1K0小数点K-1K-2
权值8421 0.50.25
系数1011 01
对于值8021 00.25

结果8+0+2+1+0+0.25=11.25

(2)十进制转二进制

方法1:按权展开法

类似于拼凑出合适的数字,例如(89)10

          对于89这个数字来说,考虑2的次方关系,寻找和89最近的这个数,  26=64 <89 <27=128,所以在26 的系数为1。剩余89-64=25。则继续考虑25。  24=16 <25 <25=32。所以24

处系数为1。剩余25-16=9。23=8,20=1

K7K6K5K4K3K2K1K0
权值1286432168421
系数 1 11  1

则结果为(1011001)2

方法2:

十进制整数转二进制数: “除2取余,逆序输出

例如:(89)10 =(1011001)2

十进制小数转二进制数: “乘2取整,顺序输出

例如:(0.625)10 =(0.101)2


2.八进制与二进制的转换

(1)八进制转二进制

每一个八进制的数都表示成一个三位二进制
方法:把每一位按权展开法

例如:(37.416)8=(11111.10000111)2

八进制37.416
二进制011111 100001      110

把高位和低位的0去掉后就是(11111.10000111)2

(2)二进制转八进制

例如:(10110.0011)2

方法:每三位二进制组成一位八进制

二进制010110.001100
八进制26 1  4   

三位为一组,不足三位的补0


3.十六进制与二进制的转换

(1)十六进制进制转二进制

例如:(5DF.9)16=(10111011111.1001)2

十六进制5DF.9
二进制010111011111.1001 

把高位和低位的0去掉后就是(10111011111.1001)2

(2)二进制进制转十六进制

 方法:从小数点开始往左往右每四位组成一个十六进制

 例如:(1100001.111)2

二进制01100001.1110
十六进制61 E

4.八进制与十进制的转换

把这个八进制的最后一位乘上80,倒数第二位81,一直乘到最高位,然后把各项乘积相加,结果即为十进制。

(36)8= 3*81 + 6*80 =24+6 =(30)10


5.十六进制与十进制的转换

把这个十六进制的最后一位乘上160,倒数第二位161,一直乘到最高位,然后把各项乘积相加,结果即为十进制。

(1E)16= 1*161 + 14*160 =16+14 =(30)10


返回目录:NOIP/CSP信息学奥赛初赛


分类: NOIP