在此程序中,您将学习使用Java中的函数将二进制数转换为八进制数,反之亦然。
在此程序中,我们将首先将二进制数字转换为十进制。然后,十进制数字转换为八进制。
public class BinaryOctal {
public static void main(String[] args) {
long binary = 101001;
int octal = convertBinarytoOctal(binary);
System.out.printf("%d 二进制 = %d 八进制", binary, octal);
}
public static int convertBinarytoOctal(long binaryNumber)
{
int octalNumber = 0, decimalNumber = 0, i = 0;
while(binaryNumber != 0)
{
decimalNumber += (binaryNumber % 10) * Math.pow(2, i);
++i;
binaryNumber /= 10;
}
i = 1;
while (decimalNumber != 0)
{
octalNumber += (decimalNumber % 8) * i;
decimalNumber /= 8;
i *= 10;
}
return octalNumber;
}
}运行该程序时,输出为:
101001 二进制 = 51 八进制
此转换发生为:
二进制到十进制 1 * 25 + 0 * 24 + 1 * 23 + 0 * 22 + 0 * 21 + 1 * 20 = 41 十进制到八进制 8 | 418 | 5 -- 1 8 | 0 -- 5 (51)
在此程序中,首先将八进制数从十进制转换为十进制。然后,将十进制数转换为二进制数。
public class OctalBinary {
public static void main(String[] args) {
int octal = 67;
long binary = convertOctalToBinary(octal);
System.out.printf("%d in octal = %d 二进制", octal, binary);
}
public static long convertOctalToBinary(int octalNumber)
{
int decimalNumber = 0, i = 0;
long binaryNumber = 0;
while(octalNumber != 0)
{
decimalNumber += (octalNumber % 10) * Math.pow(8, i);
++i;
octalNumber/=10;
}
i = 1;
while (decimalNumber != 0)
{
binaryNumber += (decimalNumber % 2) * i;
decimalNumber /= 2;
i *= 10;
}
return binaryNumber;
}
}运行该程序时,输出为:
67 in octal = 110111 二进制
此转换发生为:
八进制到十进制 6 * 81 + 7 * 80 = 55 十进制到二进制 2 | 552 | 27 -- 1 2 | 13 -- 1 2 | 6 -- 1 2 | 3 -- 0 2 | 1 -- 1 2 | 0 -- 1 (110111)