Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Выделение мантиссы и порядка из числа с плавающей запятой (double)  (Прочитано 11761 раз)
0 Пользователей и 1 Гость смотрят эту тему.
Robinson
Интересующийся

ru
Offline Offline

« : 10-12-2008 16:02 » 

Здравствуйте!
Подскажите как реализовать выделение из числа типа double мантиссы и порядка

Допустим есть число 0,0000006843

Мне нужно получить 6,843 и -7

Заранее спасибо...
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 10-12-2008 17:34 » 

Robinson, про нормализацию почитай. Все просто: число больше 10 - делишь на 10 и мантису увеличиваешь, число меньше 1 - наоборот.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Robinson
Интересующийся

ru
Offline Offline

« Ответ #2 : 10-12-2008 20:48 » 

Ну тривиальное решение типа этого я и сам уже написал:
Код:
int p = 0;

while(delta < 1)
{
delta *= 10;
p++;
}

while(delta > 10)
{
delta /= 10;
p--;
}
   
Меня интересует существует ли более элегантное решение...как я понимаю мантисса и порядок уже записаны в числе с плавающей запятой...может как-нибудь можно взять мантиссу и порядок сразу из числа?
Записан
Вад
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #3 : 10-12-2008 21:04 » 

Ну, можешь посмотреть, как побитово представлен конкретный интересующий тебя тип, и работать с этой структурой - т.е., выделить конкретный диапазон битов
Записан
Вад
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #4 : 10-12-2008 21:06 » 

Fixed: нашёл ссылку получше Улыбаюсь http://en.wikipedia.org/wiki/IEEE_754-1985#Double-precision_64_bit
« Последнее редактирование: 10-12-2008 21:10 от Вад » Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #5 : 10-12-2008 21:18 » 

Robinson, само плавающее число имеет двоичную базу, а ты хочешь получить по десятичной базе. Т.ч. не выйдет.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines