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

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

Чтобы понять этот пример, вы должны знать следующие темы программирования на C ++:

  • Функции C ++
  • Типы пользовательских функций в C ++
  • C ++ if, if… else и Nested if… else
  • C ++ while и do … while Цикл

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

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

 #include #include using namespace std; int convertBinarytoOctal(long long); int main() ( long long binaryNumber; cout <> binaryNumber; cout << binaryNumber << " in binary = " << convertBinarytoOctal(binaryNumber) << " in octal "; return 0; ) int convertBinarytoOctal(long long binaryNumber) ( int octalNumber = 0, decimalNumber = 0, i = 0; while(binaryNumber != 0) ( decimalNumber += (binaryNumber%10) * pow(2,i); ++i; binaryNumber/=10; ) i = 1; while (decimalNumber != 0) ( octalNumber += (decimalNumber % 8) * i; decimalNumber /= 8; i *= 10; ) return octalNumber; ) 

Вывод

 Введите двоичное число: 10001, 10001 в двоичном формате = 21 в восьмеричном.

Двоичное число, введенное пользователем, передается в convertBinaryToOctal()функцию. И эта функция преобразует число в восьмеричное и возвращает main()функцию

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

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

 #include #include using namespace std; long long convertOctalToBinary(int); int main() ( int octalNumber; cout <> octalNumber; cout << octalNumber << " in octal = " << convertOctalToBinary(octalNumber) << "in binary"; return 0; ) long long convertOctalToBinary(int octalNumber) ( int decimalNumber = 0, i = 0; long long binaryNumber = 0; while(octalNumber != 0) ( decimalNumber += (octalNumber%10) * pow(8,i); ++i; octalNumber/=10; ) i = 1; while (decimalNumber != 0) ( binaryNumber += (decimalNumber % 2) * i; decimalNumber /= 2; i *= 10; ) return binaryNumber; ) 

Вывод

 Введите восьмеричное число: 54 54 в восьмеричном = 101100 

Восьмеричное число, введенное пользователем, передается в convertOctalToBinary()функцию. И эта функция преобразует число в двоичное и возвращает main()функцию

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