Преобразовать число 1,5 в двоичный код в формате четырёхбайтового вещественного числа (решение и ответ письменно). Записать шестнадцатеричное представление в памяти компьютера
Ответы на вопрос:
Объяснение:
в числах одинарной точности на знак отводится 1 бит, на экспоненту - 8, на мантиссу - 23.
в нормализованных числах старший бит всегда равен единице и он не записывается в число, поэтому реально мантисса для таких чисел имеет размер 24 бита.
к экспоненте перед записью добавляется число 127.
для начала запишем знак числа. если число положительное - запишем в знак 0, если отрицательное - 1 и отбросим знак числа для дальнейших вычислений.
далее приведем число к такому виду, что перед запятой в двоичной записи у него только единица (если изначальное число 0 - оно имеет специальную запись 0 00000000 00000000000000000000000₂)
для этого либо умножаем число на 2 пока оно не станет >= 1, если оно меньше 1, либо делим на 2 пока оно все еще >= 1.
если умножаем - в экспоненту пойдет отрицательное число умножений. если делим - положительное число делений.
потом получившееся число умножаем на 2²³ (8388608), округляем до ближайшего целого и отбрасываем старший бит. результат записываем в мантиссу.
0,5 - положительное, в знак 0
0,5 < 1, умножаем его на 2, пока оно не станет >= 1. получилось 1 за 1 умножение. в экспоненту пойдет -1
мантисса = 1*8388608 = 100000000000000000000000₂. отбрасываем старший бит. получается 000000000000000000000000₂
записываем:
знак = 0 (число положительное)
в экспоненте 127 - 1 = 126 = 01111110₂
в мантиссе 000000000000000000000000₂ (без старшей единицы),
получаем:
0 01111110 00000000000000000000000₂
25,12 положительное. в знак 0
25,12 делим на 2, пока >= 1. получаем 1,57 за 4 деления (если поделим еще раз, будет уже 0,785 < 1). в экспоненту пойдет +4.
1,57 * 8388608 = 13170114,56. округляем, получаем 13170115 = 110010001111010111000011₂
отбрасываем старший бит, получаем 10010001111010111000011₂
записываем
знак = 0
экспонента = 127+4 = 10000011₂
мантисса = 10010001111010111000011₂
получаем:
0 10000011 10010001111010111000011₂
-25,12 отрицательное, записываем в знак единицу, далее отбрасываем знак числа и считаем ровно как в предыдущем примере
1 10000011 10010001111010111000011₂
-3456,1. в знак единица, отбрасываем знак.
3456,1 > 1. делим на 2¹¹. получаем 1.687548828125, в экспоненту 11
1.687548828125 * 8388608 = 14156185.6. округляем. 14156186 = 110110000000000110011010₂, отбрасываем старшую единицу: 10110000000000110011010₂
знак 1
экспонента 127 + 11 = 10001010₂
мантисса 10110000000000110011010₂
результат 1 10001010 10110000000000110011010₂
с денормализованными числами работают иначе. если интересно (в чем я сомневаюсь :)), пишите в комментарии.
Популярно: Информатика
-
Luiza21125.11.2022 07:56
-
mohammadroshann11.06.2022 03:03
-
али42124.02.2023 02:56
-
QUKKI19.01.2022 09:19
-
Alien171210.04.2021 05:01
-
КнигаЗнаний1611.01.2022 09:39
-
flash6429.06.2021 23:23
-
HaCT9I331.01.2021 11:46
-
kozinasofia200620.01.2020 08:17
-
Абухассан16.04.2023 15:01