Program Java do konwersji liczb binarnych na ósemkowe i odwrotnie

W tym programie nauczysz się konwertować liczbę binarną na liczbę ósemkową i odwrotnie, używając funkcji w Javie.

Aby zrozumieć ten przykład, należy znać następujące tematy dotyczące programowania w języku Java:

  • Metody Java
  • Operatory Java
  • Java while i zrób… while Loop

Przykład 1: Program do konwersji danych binarnych na ósemkowe

W tym programie najpierw zamienimy liczbę dwójkową na dziesiętną. Następnie liczba dziesiętna jest konwertowana na ósemkową.

 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; ) )

Wynik

 101001 dwójkowo = 51 ósemkowo

Ta konwersja odbywa się jako:

Binarne na dziesiętne 1 * 2 5 + 0 * 2 4 + 1 * 2 3 + 0 * 2 2 + 0 * 2 1 + 1 * 2 0 = 41 Dziesiętne na ósemkowe 8 | 41 8 | 5 - 1 8 | 0 - 5 (51)

Przykład 2: Program do konwersji ósemkowej na dwójkową

W tym programie liczba ósemkowa na początku jest dziesiętna. Następnie liczba dziesiętna jest konwertowana na liczbę binarną.

 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; ) )

Wynik

 67 ósemkowo = 110111 binarnie

Ta konwersja odbywa się jako:

Ósemkowe na dziesiętne 6 * 8 1 + 7 * 8 0 = 55 Dziesiętne na dwójkowe 2 | 55 2 | 27 - 1 2 | 13 - 1 2 | 6 - 1 2 | 3 - 0 2 | 1 - 1 2 | 0 - 1 (110111)

Interesujące artykuły...