Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Программирование и базы данных (http://forum.oszone.net/forumdisplay.php?f=21)
-   -   перевод из десятичной в двоичную отрицательных чисел с дробной частью (http://forum.oszone.net/showthread.php?t=279743)

meisme 24-03-2014 19:18 2328011

перевод из десятичной в двоичную отрицательных чисел с дробной частью
 
В задании нужно перевести из десятичной в двоичную систему исчисления отрицательное число с дробной частью. Проблема в том, что я не понимаю вот это:
как лучше представить число в двоичной СС:
1) отрицательное число пишется так же, как и положительное, но стоит "-" или бит знака?
2) или переводить число в дополненный код? и если переводить, то после инверсии куда прибавлять единицу? к дробной части или целой?
3) кому не сложно, переведите для примера число -125,635, желательно с объяснением.

pva 22-04-2014 14:59 2341571

meisme, Есть несколько способов представления дробных двоичных чисел. То же самое мы делаем с десятичными.
1. Фиксированная точка - мы храним в памяти целые числа в виде x = f*a, где f - наше число, a - точность, с которой мы сохраняем дробную часть. Чтобы получить дробное число f, берём из памяти целое x, делим на a.
Код:

допустим a = 1000
123567 = 123.567 * 1000
    ^ это пишем в память, т.к. в памяти только целые числа

т.о. для записи с фиксированной запятой нам нужно знать, сколько мы используем для дробной части.

Хитрый ход: если взять `a' кратно 2^8 = 256, то десятичная точка всегда будет попадать на границу байта. В памяти мы будем видеть целую часть в неизменном виде (чтобы понять надо поиграться самому).
Код:

XXXX = 123.567 * (2^16) = 123.567 * 65536 = 8098086
    ^ это пишем в память, т.к. в памяти только целые числа

В память запишется: 00 7B 91 26
Имейте в виду, что 123 - это 7B

2. Плавающая точка.
Храним в памяти целое число `x' и каким-то образом закодированное `a'. Например первые 11 бит - степень двойки для `a', остальное = число `x'. Подробнее можно прочитать здесь http://ru.wikipedia.org/wiki/%D0%A7%...81%D1%82%D0%B8 (там же есть примеры)

Tau_0 22-04-2014 23:22 2341741

meisme, и я рекомендую вот это почитать:
IEEE 754 - стандарт двоичной арифметики
с плавающей точкой


Представление чисел с плавающей точкой

Генри С. Уоррен, Алгоритмические трюки для программистов

Habetdin 23-04-2014 20:07 2342140

Цитата:

Цитата meisme
как лучше представить число в двоичной СС »

Заставить ПК вывести бинарный вид нашего числа с помощью битовых операций :)
Другой вопрос - что делать с дробными числами, для которых недоступны эти самые битовые операции? Можно объединить их в памяти с целочисленными форматами, подходящими по размеру:
Код:

union {
    float flt;
    long lng;
} x;
x.flt = 15.675;
// вывести в двоичном виде, используя x.lng

А дальше всё зависит от вашей реализации перевода в двоичный вид, пример - на ideone.
P.S.: Ну и проверка размеров типов данных, объединенных в примере на ideone
(ибо они зависят от компилятора/платформы) - здесь (эх, 43 days ago, а вроде недавно задавали...)


Время: 07:01.

Время: 07:01.
© OSzone.net 2001-