В этой программе вы научитесь преобразовывать двоичное число в восьмеричное и наоборот, используя функции Java.
Чтобы понять этот пример, вы должны знать следующие темы программирования Java:
- Методы Java
- Операторы Java
- Java while и do … while Loop
Пример 1: Программа для преобразования двоичного числа в восьмеричное
В этой программе мы сначала преобразуем двоичное число в десятичное. Затем десятичное число преобразуется в восьмеричное.
public class BinaryOctal ( public static void main(String() args) ( long binary = 101001; int octal = convertBinarytoOctal(binary); System.out.printf("%d in binary = %d in octal", 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 * 2 5 + 0 * 2 4 + 1 * 2 3 + 0 * 2 2 + 0 * 2 1 + 1 * 2 0 = 41 из десятичного в восьмеричное 8 | 41 8 | 5 - 1 8 | 0–5 (51)
Пример 2: Программа для преобразования восьмеричного числа в двоичное
В этой программе восьмеричное число сначала переводится из десятичного в десятичное. Затем десятичное число преобразуется в двоичное число.
public class OctalBinary ( public static void main(String() args) ( int octal = 67; long binary = convertOctalToBinary(octal); System.out.printf("%d in octal = %d in binary", 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 в восьмеричной системе = 110111 в двоичной
Это преобразование происходит как:
Восьмеричное в десятичное 6 * 8 1 + 7 * 8 0 = 55 десятичное в двоичное 2 | 55 2 | 27 - 1 2 | 13 - 1 2 | 6 - 1 2 | 3 - 0 2 | 1 - 1 2 | 0–1 (110111)