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

Перевод -87.2(Знаковое Дополнительный 2 байта) из десятичной в двоичную систему счисления

Введите число:
Его система счисления:
Двоичная
Троичная
Восьмеричная
Десятичная
Шестнадцатиричная
Двоично-десятичная
Другая
Дополнительно
Знаковое
Прямой
Обратный
Дополнительный
Беззнаковое
1 байт
2 байта
4 байта
8 байт

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

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

872
-86432
1-42212
1-20102
1-1052
0-422
1-21
0
Перевод чисел из одной системы счисления в другую

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

Перевод чисел из одной системы счисления в другую
0.2*2
0.4*2
0.8*2
1.6*2
1.2*2
0.4*2
0.8*2
1.6*2
1.2*2
0.4*2
0.8*2

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

87.210 = 1010111.00110011002

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

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

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

10101112 = 110101112

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

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

11010111 прямой код
10101000обратный код
+1+1 бит
10101001дополнительный код
Ответ: -87.210 = 101010012 (1 байт)