进制转换是软考必考的项目,首先对其进行复习。
进制转换模块可分为两块——R进制转10进制、10进制转R进制。
日常生活中通常使用十进制,但计算机底层都是采用二进制计算,所以会涉及到进制转换。
除法的计算公式为 被除数 ÷ 除数 = 商 + 余数
。
比如要将 94
转换为 3
进制,过程如下:
被除数 94 除以 3
,商为 31
,余数为 1
;
被除数 31 除以 3
,商为 10
,余数为 1
;
被除数 10 除以 3
,商为 3
,余数为 1
;
被除数 3 除以 3
,商为 1
,余数为 0
;
被除数 1 除以 3
,商为 0
,余数为 1
;
所以从下到上,答案就是10111
,如下图所示。
比如要将 68
转换为 6
进制,过程如下:
被除数 68
除以 6
,商为 11
,余数为 2
;
被除数 11
除以 6
,商为 1
,余数为 5
;
被除数 1
除以 6
,商为 0
,余数为 1
;
所以从下到上,答案就是152
,如下图所示。
结果可以采用 Java 程序验证,相关代码如下。
public static void main(String[] args) {
// 转换前数字
Integer number = 94;
// 转换结果
String ans = Integer.toString(number,3);
// 94 转换为 3进制,答案为 10111
System.out.println(ans);
}
将 R 进制数的每一位拆为幂次方形式,幂的底数为 R,指数为 K,K 是数位和小数点的有向距离,左边为正,右边为负。
16进制数 6A8
转10
进制
第一位 6
,拆分为 6 乘 16
的 2
次方。
第二位 A
(即10),拆分为10
乘 16
的 1
次方。
第三位 8
,拆分为 8
乘 16
的 0
次方。
再将所有结果相加,最终得到 1701
的答案,如下图所示。
比如13进制数 8B7 转10进制
第一位 8
,拆分为 8
乘 13
的 2
次方。
第二位 B
(即11),拆分为11 乘 13
的 1
次方。
第三位 7
,拆分为 7
乘 13
的 0
次方。
再将所有结果相加,最终得到 1502
的答案,如下图所示。
结果可以采用 Java 程序验证,相关代码如下。
public static void main(String[] args) {
String number = "8B7";
Integer ans = Integer.parseInt(number,13);
System.out.println(ans);
}
今天对进制转换进行了学习,掌握了 R 进制转 10 进制
和 10进制转 R 进制
的方法。