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

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

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

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

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

902
-90452
0-44222
1-22112
0-1052
1-422
1-21
0
Перевод чисел из одной системы счисления в другую

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

Перевод чисел из одной системы счисления в другую
0.59*2
1.18*2
0.36*2
0.72*2
1.44*2
0.88*2
1.76*2
1.52*2
1.04*2
0.08*2
0.16*2

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

90.5910 = 1011010.10010111002

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

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

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

10110102 = 110110102

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

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

11011010 прямой код
.
10100101обратный код
+1+1 бит
10100110дополнительный код
Ответ: -90.5910 = 101001102 (1 байт)