Программа Kotlin для преобразования двоичного числа в восьмеричное и наоборот

В этой программе вы научитесь преобразовывать двоичное число в восьмеричное и наоборот, используя функции в Kotlin.

Пример 1: Программа для преобразования двоичного числа в восьмеричное

В этой программе мы сначала преобразуем двоичное число в десятичное. Затем десятичное число преобразуется в восьмеричное.

 fun main(args: Array) ( val binary: Long = 101001 val octal = convertBinarytoOctal(binary) println("$binary in binary = $octal in octal") ) fun convertBinarytoOctal(binaryNumber: Long): Int ( var binaryNumber = binaryNumber var octalNumber = 0 var decimalNumber = 0 var i = 0 while (binaryNumber.toInt() != 0) ( decimalNumber += (binaryNumber % 10 * Math.pow(2.0, i.toDouble())).toInt() ++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: Программа для преобразования восьмеричного числа в двоичное

В этой программе восьмеричное число сначала переводится из десятичного в десятичное. Затем десятичное число преобразуется в двоичное число.

 fun main(args: Array) ( val octal = 67 val binary = convertOctalToBinary(octal) println("$octal in octal = $binary in binary") ) fun convertOctalToBinary(octalNumber: Int): Long ( var octalNumber = octalNumber var decimalNumber = 0 var i = 0 var binaryNumber: Long = 0 while (octalNumber != 0) ( decimalNumber += (octalNumber % 10 * Math.pow(8.0, i.toDouble())).toInt() ++i octalNumber /= 10 ) i = 1 while (decimalNumber != 0) ( binaryNumber += (decimalNumber % 2 * i).toLong() 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)

Вот эквивалентный код Java: Программа Java для преобразования двоичного кода в восьмеричный и наоборот

Интересные статьи...