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

В този пример ще се научите да конвертирате двоично число в осмично и осмично число в двоично ръчно чрез създаване на дефинирана от потребителя функция.

За да разберете този пример, трябва да имате познанията по следните теми за програмиране на C ++:

  • C ++ функции
  • Видове дефинирани от потребителя функции в C ++
  • C ++ ако, ако … друго и вложено ако … друго
  • C ++ докато и правя … докато Loop

Пример 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()функцията

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