https://mathweb.ru/numberconverter.html?id=231930

Перевод -139.375 из десятичной в двоичную систему счисления

Введите число:
Его система счисления:
Двоичная
Троичная
Восьмеричная
Десятичная
Шестнадцатиричная
Двоично-десятичная
Другая
Дополнительно

Переведем число 139.37510 в двоичное вот так:

Целая часть числа находится делением на основание новой системы счисления:

1392
-138692
1-68342
1-34172
0-1682
1-842
0-422
0-21
0
Перевод чисел из одной системы счисления в другую

Дробная часть числа находится умножением на основание новой системы счисления:

Перевод чисел из одной системы счисления в другую
0.375*2
0.75*2
1.5*2
1.0*2

В результате преобразования получилось:

139.37510 = 10001011.0112

Вы указали что размер вашего числа 4 байт.

На данный момент отрицательные дробные числа не поддерживаются. Поэтому в дальнейшем переводе участвует только целая часть числа.

Дополним число знаковым битом вот так:

100010112 = 100000000000000000000000100010112

Так-как введенное Вами число отрицательное то необходимо перевести его из прямого кода в дополнительный.

Для этого сначала выполним преобразование из прямого кода в обратный инвертированием всех битов кроме знакового, затем получим прямой код добавлением 1 бита.

10000000000000000000000010001011 прямой код
11111111111111111111111101110100обратный код
+1+1 бит
11111111111111111111111101110101дополнительный код
Ответ: -139.37510 = 111111111111111111111111011101012 (4 байт)