各种进制转换方法

如题所述

一)、数制
计算机中采用的是二进制,因为二进制具有运算简单,易实现且可靠,为逻辑设计提供了有利的途径、节省设备等优点,为了便于描述,又常用八、十六进制作为二进制的缩写。

一般计数都采用进位计数,其特点是:
(1)逢N进一,N是每种进位计数制表示一位数所需要的符号数目为基数。
(2)采用位置表示法,处在不同位置的数字所代表的值不同,而在固定位置上单位数字表示的值是确定的,这个固定位上的值称为权。
在计算机中:D7 D6 D5 D4 D3 D2 D1 D0 只有两种0和1
8 4 2 1

二)、数制转换
不同进位计数制之间的转换原则:不同进位计数制之间的转换是根据两个有理数如相等,则两数的整数和分数部分一定分别相等的原则进行的。也就是说,若转换前两数相等,转换后仍必须相等。
有四进制
十进制:有10个基数:0 ~~ 9 ,逢十进一
二进制:有2 个基数:0 ~~ 1 ,逢二进一
八进制:有8个基数:0 ~~ 7 ,逢八进一
十六进制:有16个基数:0 ~~ 9,A,B,C,D,E,F (A=10,B=11,C=12,D=13,E=14,F=15) ,逢十六进一

1、数的进位记数法
N=a n-1*p n-1+a n-2*p n-2+…+a2*p2+a1*p1+a0*p0
2、十进制数与P进制数之间的转换
①十进制转换成二进制:十进制整数转换成二进制整数通常采用除2取余法,小数部分乘2取整法。例如,将(30)10转换成二进制数
将(30)10转换成二进制数
2| 30 ….0 ----最右位
2 15 ….1
2 7 ….1
2 3 ….1
1 ….1 ----最左位
∴ (30)10=(11110)2
将(30)10转换成八、十六进制数
8| 30 ……6 ------最右位
3 ------最左位
∴ (30)10 =(36)8

16| 30 …14(E)----最右位
1 ----最左位
∴ (30)10 =(1E)16
3、将P进制数转换为十进制数
把一个二进制转换成十进制采用方法:把这个二进制的最后一位乘上20,倒数第二位乘上21,……,一直到最高位乘上2n,然后将各项乘积相加的结果就它的十进制表达式
把二进制11110转换为十进制
(11110)2=1*24+1*23+1*22+1*21+0*20=
=16+8+4+2+0
=(30)10

把一个八进制转换成十进制采用方法:把这个八进制的最后一位乘上80,倒数第二位乘上81,……,一直到最高位乘上8n,然后将各项乘积相加的结果就它的十进制表达式。
把八进制36转换为十进制
(36)8=3*81+6*80=24+6=(30)10
把一个十六进制转换成十进制采用方法:把这个十六进制的最后一位乘上160,倒数第二位乘上161,……,一直到最高位乘上16n,然后将各项乘积相加的结果就它的十进制表达式。
把十六制1E转换为十进制
(1E)16=1*161+14*160=16+14=(30)10
3、二进制转换成八进制数
(1)二进制数转换成八进制数:对于整数,从低位到高位将二进制数的每三位分为一组,若不够三位时,在高位左面添0,补足三位,然后将每三位二进制数用一位八进制数替换,小数部分从小数点开始,自左向右每三位一组进行转换即可完成。例如:
将二进制数1101001转换成八进制数,则
(001 101 001)2
| | |
( 1 5 1)8
( 1101001)2=(151)8

(2)八进制数转换成二进制数:只要将每位八进制数用三位二进制数替换,即可完成转换,例如,把八进制数(643.503)8,转换成二进制数,则
(6 4 3 . 5 0 3)8
| | | | | |
(110 100 011 . 101 000 011)2
(643.503)8=(110100011.101000011)2
4、二进制与十六进制之间的转换
(1)二进制数转换成十六进制数:由于2的4次方=16,所以依照二进制与八进制的转换方法,将二进制数的每四位用一个十六进制数码来表示,整数部分以小数点为界点从右往左每四位一组转换,小数部分从小数点开始自左向右每四位一组进行转换。
(2)十六进制转换成二进制数
如将十六进制数转换成二进制数,只要将每一位十六进制数用四位相应的二进制数表示,即可完成转换。
例如:将(163.5B)16转换成二进制数,则
( 1 6 3 . 5 B )16
| | | | |
(0001 0110 0011. 0101 1011 )2
(163.5B)16=(101100011.01011011)2
温馨提示:答案为网友推荐,仅供参考
第1个回答  2020-11-11
进制转换的方法是:二进制数,十六进制数可以采用按权展开法转化为十进制数,十进制转化为R进制要分为两部分,其中整数部分要除R取余,直到商为0,小数部分要乘R取余直到得到整数。
进制也就是进制位,对于接触过电脑的人来说应该都不陌生,我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。接下来将在文章中为大家详细介绍,希望对大家有所帮助。

一:简述:

进位计数制:是人们利用符号来计数的方法。一种进位计数制包含一组数码符号和两个基本因素。

(1)数码:用不同的数字符号来表示一种数制的数值,这些数字符号称为“数码”。

(2)基:数制所使用的数码个数称为”基”。

(3)权:某数制每一位所具有的值称为”权”。

二:进制转换的理论

1、二进制数、十六进制数转换为十进制数:用按权展开法

把一个任意R进制数an an-1 ...a1a0 . a-1 a-2...a-m

转换成十进制数,其十进制数值为每一位数字与其位权之积的和。

an×R n + an-1×R n-1 +…+ a1×R 1 + a0×R 0 + a-1 ×R-1+ a-2×R-2+ …+ a-m×R-m

2: 十进制转化成R进制

十进制数轮换成R进制数要分两个部分:

整数部分:除R取余数,直到商为0,得到的余数即为二进数各位的数码,余数从右到左排列(反序排 列)。

小数部分:乘R取整数,得到的整数即为二进数各位的数码,整数从左到右排列(顺序排列)。

3:十六进制转化成二进制

每一位十六进制数对应二进制的四位,逐位展开。

4: 二进制转化成十六进制

将二进制数从小数点开始分别向左(对二进制整数)或向右(对二进制小数)每四位组成一组,不足四位补零。

三:具体实现

1:二进制转换成十进制

任何一个二进制数的值都用它的按位权展开式表示。

例如:将二进制数(10101.11)2转换成十进制数。

(10101.11)2=1*24+0*23+1*22+0*21+1*20+1*2-1+1*2-2

=24+22+20+2-1+2-2=(21.75)10

2:十进制整理转换成二进制

将十进制整数转换成二进制整数采用“除2取倒余法”。

即将十进制整数除以2,得到一个商和一个余数;再将商除以2,又得到一个商和一个余数;

以此类推,直到商等于零为止。

每次得到的余数的倒排列,就是对应二进制数的各位数。

于是,结果是余数的倒排列,即为:

(37)10=(a5a4a3a2a1a0)2=(100101)2

3:十进制小数转换成二进制小数

十进制小数转换成二进制小数是用“乘2取整法”。即用2逐次去乘十进制小数,

将每次得到的积的整数部分按各自出现的先后顺序依次排列,就得到相对应的二进制小数。

将十进制小数0.375转换成二进制小数,其过程如下:

最后结果:(0.375)10=(0.a1a2a3)2=(0.011)2

4:十六进制转为二进制

由于24=16,所以每一位十六进制数要用四位二进制数来表示,也就是将每一位十六进制数表示成四位二进制数。

例:将十六进制数(B6E.9)16转换成二进制数为:

B  6  E .  9

1011 0110 1110 . 1001

即(B6E.9)16=(101101101110.1001)2

5:二进制数转为十六进制

将二进制数转换成十六进制数是将二进数的整数部分从右向左每四位一组,每一组为一位十六进制整数,不足四位时,在前面补0;

而二进制小数转换成十六进制小数是将二进制小数部分从左向右每四位一组,每一组为一位十六进制小数。

最后一组不足四位时,应在后面用0补足四位。

例:二进制数(1010101011.0110)2,转换成十六进制数为:

0010 1010 1011 . 0110

2  A  B  . 6

即:(10 1010 1011.0110)2=(2AB.6)16

十进制小数转换二进制:

用的通俗易懂的说法:用这个小数不断乘2,直到这个小数变为整数后,然后这个整数就转为二进制了,接着,刚才乘了几次2,你就把这个二进制的小数点像坐移几位即可

例:0.75

0.75X2=1.5

1.5X2=3

得到整数3,现在把3转为二进制,如下:

3(10)=》11(2)

得到二进制数:11

因为刚才乘了2次“2”,所以小数像左易懂2位,最终结果:0.11

有些小数乘2是永得不到整数的,那就看他要求的精度,假如要求保留3位小数,则乘3次“2”即可,后面的小数可以无视,直接拿直面的整数部分转为二进制,再向左移3位.

如此类推....

以上就是进制转换方法是什么的详细内容,更多请关注php中文网其它相关文章!
第2个回答  2020-11-11
进制转换的方法是:二进制数,十六进制数可以采用按权展开法转化为十进制数,十进制转化为R进制要分为两部分,其中整数部分要除R取余,直到商为0,小数部分要乘R取余直到得到整数。
进制也就是进制位,对于接触过电脑的人来说应该都不陌生,我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。接下来将在文章中为大家详细介绍,希望对大家有所帮助。
一:简述:
进位计数制:是人们利用符号来计数的方法。一种进位计数制包含一组数码符号和两个基本因素。
(1)数码:用不同的数字符号来表示一种数制的数值,这些数字符号称为“数码”。
(2)基:数制所使用的数码个数称为”基”。
(3)权:某数制每一位所具有的值称为”权”。
二:进制转换的理论
1、二进制数、十六进制数转换为十进制数:用按权展开法
把一个任意R进制数an an-1 ...a1a0 . a-1 a-2...a-m
转换成十进制数,其十进制数值为每一位数字与其位权之积的和。
an×R n + an-1×R n-1 +…+ a1×R 1 + a0×R 0 + a-1 ×R-1+ a-2×R-2+ …+ a-m×R-m
2: 十进制转化成R进制
十进制数轮换成R进制数要分两个部分:
整数部分:除R取余数,直到商为0,得到的余数即为二进数各位的数码,余数从右到左排列(反序排列)。
小数部分:乘R取整数,得到的整数即为二进数各位的数码,整数从左到右排列(顺序排列)。
3:十六进制转化成二进制
每一位十六进制数对应二进制的四位,逐位展开。
4: 二进制转化成十六进制
将二进制数从小数点开始分别向左(对二进制整数)或向右(对二进制小数)每四位组成一组,不足四位补零。
三:具体实现
1:二进制转换成十进制
任何一个二进制数的值都用它的按位权展开式表示。
例如:将二进制数(10101.11)2转换成十进制数。
(10101.11)2=1*24+0*23+1*22+0*21+1*20+1*2-1+1*2-2
=24+22+20+2-1+2-2=(21.75)10
2:十进制整理转换成二进制
将十进制整数转换成二进制整数采用“除2取倒余法”。
即将十进制整数除以2,得到一个商和一个余数;再将商除以2,又得到一个商和一个余数;
以此类推,直到商等于零为止。
每次得到的余数的倒排列,就是对应二进制数的各位数。
于是,结果是余数的倒排列,即为:
(37)10=(a5a4a3a2a1a0)2=(100101)2
3:十进制小数转换成二进制小数
十进制小数转换成二进制小数是用“乘2取整法”。即用2逐次去乘十进制小数,
将每次得到的积的整数部分按各自出现的先后顺序依次排列,就得到相对应的二进制小数。
将十进制小数0.375转换成二进制小数,其过程如下:
最后结果:(0.375)10=(0.a1a2a3)2=(0.011)2
4:十六进制转为二进制
由于24=16,所以每一位十六进制数要用四位二进制数来表示,也就是将每一位十六进制数表示成四位二进制数。
例:将十六进制数(B6E.9)16转换成二进制数为:
B  6  E .  9
1011 0110 1110 . 1001
即(B6E.9)16=(101101101110.1001)2
5:二进制数转为十六进制
将二进制数转换成十六进制数是将二进数的整数部分从右向左每四位一组,每一组为一位十六进制整数,不足四位时,在前面补0;
而二进制小数转换成十六进制小数是将二进制小数部分从左向右每四位一组,每一组为一位十六进制小数。
最后一组不足四位时,应在后面用0补足四位。
例:二进制数(1010101011.0110)2,转换成十六进制数为:
0010 1010 1011 . 0110
2  A  B  . 6
即:(10 1010 1011.0110)2=(2AB.6)16
十进制小数转换二进制:
用的通俗易懂的说法:用这个小数不断乘2,直到这个小数变为整数后,然后这个整数就转为二进制了,接着,刚才乘了几次2,你就把这个二进制的小数点像坐移几位即可
例:0.75
0.75X2=1.5
1.5X2=3
得到整数3,现在把3转为二进制,如下:
3(10)=》11(2)
得到二进制数:11
因为刚才乘了2次“2”,所以小数像左易懂2位,最终结果:0.11
有些小数乘2是永得不到整数的,那就看他要求的精度,假如要求保留3位小数,则乘3次“2”即可,后面的小数可以无视,直接拿直面的整数部分转为二进制,再向左移3位.
如此类推....
第3个回答  2020-11-11
进制转换的方法是:二进制数,十六进制数可以采用按权展开法转化为十进制数,十进制转化为R进制要分为两部分,其中整数部分要除R取余,直到商为0,小数部分要乘R取余直到得到整数。
进制也就是进制位,对于接触过电脑的人来说应该都不陌生,我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。接下来将在文章中为大家详细介绍,希望对大家有所帮助。

一:简述:

进位计数制:是人们利用符号来计数的方法。一种进位计数制包含一组数码符号和两个基本因素。

(1)数码:用不同的数字符号来表示一种数制的数值,这些数字符号称为“数码”。

(2)基:数制所使用的数码个数称为”基”。

(3)权:某数制每一位所具有的值称为”权”。

二:进制转换的理论

1、二进制数、十六进制数转换为十进制数:用按权展开法

把一个任意R进制数an an-1 ...a1a0 . a-1 a-2...a-m

转换成十进制数,其十进制数值为每一位数字与其位权之积的和。

an×R n + an-1×R n-1 +…+ a1×R 1 + a0×R 0 + a-1 ×R-1+ a-2×R-2+ …+ a-m×R-m

2: 十进制转化成R进制

十进制数轮换成R进制数要分两个部分:

整数部分:除R取余数,直到商为0,得到的余数即为二进数各位的数码,余数从右到左排列(反序排 列)。

小数部分:乘R取整数,得到的整数即为二进数各位的数码,整数从左到右排列(顺序排列)。

3:十六进制转化成二进制

每一位十六进制数对应二进制的四位,逐位展开。

4: 二进制转化成十六进制

将二进制数从小数点开始分别向左(对二进制整数)或向右(对二进制小数)每四位组成一组,不足四位补零。

三:具体实现

1:二进制转换成十进制

任何一个二进制数的值都用它的按位权展开式表示。

例如:将二进制数(10101.11)2转换成十进制数。

(10101.11)2=1*24+0*23+1*22+0*21+1*20+1*2-1+1*2-2

=24+22+20+2-1+2-2=(21.75)10

2:十进制整理转换成二进制

将十进制整数转换成二进制整数采用“除2取倒余法”。

即将十进制整数除以2,得到一个商和一个余数;再将商除以2,又得到一个商和一个余数;

以此类推,直到商等于零为止。

每次得到的余数的倒排列,就是对应二进制数的各位数。

于是,结果是余数的倒排列,即为:

(37)10=(a5a4a3a2a1a0)2=(100101)2

3:十进制小数转换成二进制小数

十进制小数转换成二进制小数是用“乘2取整法”。即用2逐次去乘十进制小数,

将每次得到的积的整数部分按各自出现的先后顺序依次排列,就得到相对应的二进制小数。

将十进制小数0.375转换成二进制小数,其过程如下:

最后结果:(0.375)10=(0.a1a2a3)2=(0.011)2

4:十六进制转为二进制

由于24=16,所以每一位十六进制数要用四位二进制数来表示,也就是将每一位十六进制数表示成四位二进制数。

例:将十六进制数(B6E.9)16转换成二进制数为:

B  6  E .  9

1011 0110 1110 . 1001

即(B6E.9)16=(101101101110.1001)2

5:二进制数转为十六进制

将二进制数转换成十六进制数是将二进数的整数部分从右向左每四位一组,每一组为一位十六进制整数,不足四位时,在前面补0;

而二进制小数转换成十六进制小数是将二进制小数部分从左向右每四位一组,每一组为一位十六进制小数。

最后一组不足四位时,应在后面用0补足四位。

例:二进制数(1010101011.0110)2,转换成十六进制数为:

0010 1010 1011 . 0110

2  A  B  . 6

即:(10 1010 1011.0110)2=(2AB.6)16

十进制小数转换二进制:

用的通俗易懂的说法:用这个小数不断乘2,直到这个小数变为整数后,然后这个整数就转为二进制了,接着,刚才乘了几次2,你就把这个二进制的小数点像坐移几位即可

例:0.75

0.75X2=1.5

1.5X2=3

得到整数3,现在把3转为二进制,如下:

3(10)=》11(2)

得到二进制数:11

因为刚才乘了2次“2”,所以小数像左易懂2位,最终结果:0.11

有些小数乘2是永得不到整数的,那就看他要求的精度,假如要求保留3位小数,则乘3次“2”即可,后面的小数可以无视,直接拿直面的整数部分转为二进制,再向左移3位.
第4个回答  2020-11-11
二进制基数为2,进位规则是“逢二进一”,借位规则是“借一当二”。
八进制以8为基数的计数法,采用0,1,2,3,4,5,6,7八个数字,逢八进1。
十进制数是组成以10为基础的数字系统,有0,1,2,3, 4, 5, 6, 7, 8, 9十个基本数字组成。即1.满十进一,满二十进二,以此类推……2.按权展开,第一位权为10^0,第二位10^1……以此类推,第N位10^(N-1),该数的数值等于每位位的数值*该位对应的权值之和。
十六进制逢16进1的进位制,一般用数字0到9和字母A到F(或a~f)表示,其中:A~F表示10~15。
相似回答